订单列表:列表重构 ③ 添加备注表单和发货表单

(cherry picked from commit 0d202a7a85)
pull/245/head
puhui999 2023-08-22 00:38:44 +08:00 committed by shizhong
parent b74d4df4f8
commit 9efe122318
6 changed files with 209 additions and 27 deletions

View File

@ -19,6 +19,11 @@ export const getDeliveryExpress = async (id: number) => {
return await request.get({ url: '/trade/delivery/express/get?id=' + id }) return await request.get({ url: '/trade/delivery/express/get?id=' + id })
} }
// 获得商品品牌精简信息列表
export const getSimpleDeliveryExpressList = () => {
return request.get({ url: '/trade/delivery/express/list-all-simple' })
}
// 新增快递公司 // 新增快递公司
export const createDeliveryExpress = async (data: DeliveryExpressVO) => { export const createDeliveryExpress = async (data: DeliveryExpressVO) => {
return await request.post({ url: '/trade/delivery/express/create', data }) return await request.post({ url: '/trade/delivery/express/create', data })

View File

@ -94,17 +94,18 @@ export const getOrder = async (id: number | null) => {
return await request.get({ url: `/trade/order/get-detail?id=` + id }) return await request.get({ url: `/trade/order/get-detail?id=` + id })
} }
// 新增交易订单 export interface DeliveryVO {
export const createOrder = async (data: OrderVO) => { id: number // 订单编号
return await request.post({ url: `/trade/order/create`, data }) logisticsId: number | null // 物流公司编号
logisticsNo: string // 物流编号
} }
// 修改交易订单 // 订单发货
export const updateOrder = async (data: OrderVO) => { export const delivery = async (data: DeliveryVO) => {
return await request.put({ url: `/trade/order/update`, data }) return await request.post({ url: `/trade/order/delivery`, data })
} }
// 删除交易订单 // 订单备注
export const deleteOrder = async (id: number | null) => { export const remark = async (data) => {
return await request.delete({ url: `/trade/order/delete?id=` + id }) return await request.post({ url: `/trade/order/remark`, data })
} }

View File

@ -0,0 +1,93 @@
<template>
<Dialog v-model="dialogVisible" title="订单发货" width="25%">
<el-form ref="formRef" v-loading="formLoading" :model="formData" label-width="80px">
<el-form-item label="发货方式">
<el-radio-group v-model="radio">
<el-radio border label="1">快递物流</el-radio>
<el-radio border label="2">无需发货</el-radio>
</el-radio-group>
</el-form-item>
<template v-if="radio === '1'">
<el-form-item label="物流公司">
<el-select v-model="formData.logisticsId" placeholder="请选择" style="width: 100%">
<el-option
v-for="item in deliveryExpressList"
:key="item.id"
:label="item.name"
:value="item.id"
/>
</el-select>
</el-form-item>
<el-form-item label="物流单号">
<el-input v-model="formData.logisticsNo" />
</el-form-item>
</template>
</el-form>
<template #footer>
<el-button :disabled="formLoading" type="primary" @click="submitForm"> </el-button>
<el-button @click="dialogVisible = false"> </el-button>
</template>
</Dialog>
</template>
<script lang="ts" setup>
import * as DeliveryExpressApi from '@/api/mall/trade/delivery/express'
import * as TradeOrderApi from '@/api/mall/trade/order'
defineOptions({ name: 'DeliveryOrderForm' })
const { t } = useI18n() //
const message = useMessage() //
const dialogVisible = ref(false) //
const formLoading = ref(false) // 12
const radio = ref('1')
const formData = ref<TradeOrderApi.DeliveryVO>({
id: 0, //
logisticsId: null, //
logisticsNo: '' //
})
const formRef = ref() // Ref
/** 打开弹窗 */
const open = async (orderId: number) => {
resetForm()
//
formData.value.id = orderId
dialogVisible.value = true
}
defineExpose({ open }) // open
/** 提交表单 */
const emit = defineEmits(['success']) // success
const submitForm = async () => {
//
formLoading.value = true
try {
const data = unref(formData)
if (radio.value === '2') {
data.logisticsId = 0
}
await TradeOrderApi.delivery(data)
message.success(t('common.updateSuccess'))
dialogVisible.value = false
//
emit('success', true)
} finally {
formLoading.value = false
}
}
/** 重置表单 */
const resetForm = () => {
formData.value = {
id: 0, //
logisticsId: null, //
logisticsNo: '' //
}
formRef.value?.resetFields()
}
const deliveryExpressList = ref([])
onMounted(async () => {
deliveryExpressList.value = await DeliveryExpressApi.getSimpleDeliveryExpressList()
})
</script>

View File

@ -0,0 +1,66 @@
<template>
<Dialog v-model="dialogVisible" title="订单备注" width="25%">
<el-form ref="formRef" v-loading="formLoading" :model="formData" label-width="80px">
<el-form-item label="备注">
<el-input v-model="formData.remark" />
</el-form-item>
</el-form>
<template #footer>
<el-button :disabled="formLoading" type="primary" @click="submitForm"> </el-button>
<el-button @click="dialogVisible = false"> </el-button>
</template>
</Dialog>
</template>
<script lang="ts" setup>
import * as TradeOrderApi from '@/api/mall/trade/order'
defineOptions({ name: 'OrderRemarksForm' })
const { t } = useI18n() //
const message = useMessage() //
const dialogVisible = ref(false) //
const formLoading = ref(false) // 12
const formData = ref({
id: 0, //
remark: '' //
})
const formRef = ref() // Ref
/** 打开弹窗 */
const open = async (row: TradeOrderApi.OrderVO) => {
resetForm()
//
formData.value.id = row.id
formData.value.remark = row.remark
dialogVisible.value = true
}
defineExpose({ open }) // open
/** 提交表单 */
const emit = defineEmits(['success']) // success
const submitForm = async () => {
//
formLoading.value = true
try {
const data = unref(formData)
await TradeOrderApi.remark(data)
message.success(t('common.updateSuccess'))
dialogVisible.value = false
//
emit('success', true)
} finally {
formLoading.value = false
}
}
/** 重置表单 */
const resetForm = () => {
formData.value = {
id: 0, //
logisticsId: null, //
logisticsNo: '' //
}
formRef.value?.resetFields()
}
</script>

View File

@ -47,9 +47,9 @@
<el-descriptions-item label-class-name="no-colon"> <el-descriptions-item label-class-name="no-colon">
<el-button size="small" type="primary">调整价格</el-button> <el-button size="small" type="primary">调整价格</el-button>
<!-- TODO 芋艿待实现 --> <!-- TODO 芋艿待实现 -->
<el-button size="small" type="primary">备注</el-button> <el-button size="small" type="primary" @click="openForm('remark')"></el-button>
<!-- TODO 芋艿待实现 --> <!-- TODO 芋艿待实现 -->
<el-button size="small" type="primary">发货</el-button> <el-button size="small" type="primary" @click="openForm('delivery')"></el-button>
<!-- TODO 芋艿待实现 --> <!-- TODO 芋艿待实现 -->
<el-button size="small" type="primary">修改地址</el-button> <el-button size="small" type="primary">修改地址</el-button>
<!-- TODO 芋艿待实现 --> <!-- TODO 芋艿待实现 -->
@ -212,17 +212,20 @@
</el-descriptions> </el-descriptions>
</div> </div>
</ContentWrap> </ContentWrap>
<DeliveryOrderForm ref="deliveryOrderFormRef" @success="getDetail" />
<OrderRemarksForm ref="orderRemarksFormRef" @success="getDetail" />
</template> </template>
<script lang="ts" setup> <script lang="ts" setup>
import * as TradeOrderApi from '@/api/mall/trade/order' import * as TradeOrderApi from '@/api/mall/trade/order'
import { formatToFraction } from '@/utils' import { formatToFraction } from '@/utils'
import { DICT_TYPE } from '@/utils/dict' import { DICT_TYPE } from '@/utils/dict'
import OrderRemarksForm from '@/views/mall/trade/order/OrderRemarksForm.vue'
import DeliveryOrderForm from '@/views/mall/trade/order/DeliveryOrderForm.vue'
defineOptions({ name: 'TradeOrderDetailForm' }) defineOptions({ name: 'TradeOrderDetailForm' })
const message = useMessage() // const message = useMessage() //
const { params } = useRoute() // const { params } = useRoute() //
// const loading = ref(false)
const orderInfo = ref<TradeOrderApi.OrderVO>({ const orderInfo = ref<TradeOrderApi.OrderVO>({
no: '', no: '',
createTime: null, createTime: null,
@ -332,6 +335,20 @@ const detailInfo = ref({
goodsInfo: [] // tableData goodsInfo: [] // tableData
}) })
const deliveryOrderFormRef = ref() // Ref
const orderRemarksFormRef = ref() // Ref
const openForm = (type: string) => {
switch (type) {
case 'remark':
orderRemarksFormRef.value?.open(orderInfo)
break
case 'delivery':
deliveryOrderFormRef.value?.open(orderInfo.id)
break
}
}
/** 获得详情 */ /** 获得详情 */
const getDetail = async () => { const getDetail = async () => {
const id = params.orderId as unknown as number const id = params.orderId as unknown as number

View File

@ -178,6 +178,10 @@
</el-button> </el-button>
<template #dropdown> <template #dropdown>
<el-dropdown-menu> <el-dropdown-menu>
<el-dropdown-item command="delivery">
<Icon icon="ep:takeaway-box" />
发货
</el-dropdown-item>
<el-dropdown-item command="orderRemarks"> <el-dropdown-item command="orderRemarks">
<Icon icon="ep:chat-line-square" /> <Icon icon="ep:chat-line-square" />
订单备注 订单备注
@ -186,14 +190,6 @@
<Icon icon="ep:credit-card" /> <Icon icon="ep:credit-card" />
立即退款 立即退款
</el-dropdown-item> </el-dropdown-item>
<el-dropdown-item command="printReceipt">
<Icon icon="ep:takeaway-box" />
打印小票
</el-dropdown-item>
<el-dropdown-item command="printInvoice">
<Icon icon="ep:takeaway-box" />
打印配货单
</el-dropdown-item>
</el-dropdown-menu> </el-dropdown-menu>
</template> </template>
</el-dropdown> </el-dropdown>
@ -257,10 +253,14 @@
@pagination="getList" @pagination="getList"
/> />
</ContentWrap> </ContentWrap>
<DeliveryOrderForm ref="deliveryOrderFormRef" @success="getList" />
<OrderRemarksForm ref="orderRemarksFormRef" @success="getList" />
</template> </template>
<script lang="ts" name="Order" setup> <script lang="ts" name="Order" setup>
import type { FormInstance, TableColumnCtx } from 'element-plus' import type { FormInstance, TableColumnCtx } from 'element-plus'
import DeliveryOrderForm from './DeliveryOrderForm.vue'
import OrderRemarksForm from './OrderRemarksForm.vue'
import { dateFormatter } from '@/utils/formatTime' import { dateFormatter } from '@/utils/formatTime'
import * as TradeOrderApi from '@/api/mall/trade/order' import * as TradeOrderApi from '@/api/mall/trade/order'
import { OrderItemRespVO, OrderVO } from '@/api/mall/trade/order' import { OrderItemRespVO, OrderVO } from '@/api/mall/trade/order'
@ -275,7 +275,9 @@ const { currentRoute, push } = useRouter() // 路由跳转
const loading = ref(true) // const loading = ref(true) //
const total = ref(2) // const total = ref(2) //
const list = ref<OrderVO[]>([]) // const list = ref<OrderVO[]>([]) //
const openForm = (id) => { const deliveryOrderFormRef = ref()
const orderRemarksFormRef = ref()
const openForm = (id: number) => {
push('/trade/order/detail/' + id) push('/trade/order/detail/' + id)
} }
/** 商品图预览 */ /** 商品图预览 */
@ -314,19 +316,17 @@ const handleCommand = (command: string, row: OrderVO) => {
console.log(row) console.log(row)
switch (command) { switch (command) {
case 'orderRemarks': case 'orderRemarks':
orderRemarksFormRef.value?.open(row)
break break
case 'refund': case 'refund':
break break
case 'printReceipt': case 'delivery':
break deliveryOrderFormRef.value?.open(row.id)
case 'printInvoice':
break
default:
break break
} }
} }
const queryFormRef = ref<FormInstance>() // const queryFormRef = ref<FormInstance>() //
// // TODO
const queryParams = reactive({ const queryParams = reactive({
pageNo: 1, // pageNo: 1, //
pageSize: 10, // pageSize: 10, //