feat(mes): 更新退货单相关字段及逻辑优化

- 修改退货数量字段名称为 `quantity`,以简化代码。
- 更新退货原因字段为必填项,确保数据完整性。
- 优化部分逻辑,提升代码可读性和维护性。
pull/871/MERGE
YunaiV 2026-03-01 22:47:51 +08:00
parent 38f3e73486
commit 48b9e54fd8
6 changed files with 33 additions and 38 deletions

View File

@ -5,7 +5,7 @@ export interface WmReturnSalesVO {
id?: number
code?: string
name: string
soCode?: string
salesOrderCode?: string
clientId?: number
clientCode?: string
clientName?: string

View File

@ -301,4 +301,5 @@ export enum DICT_TYPE {
MES_WM_RETURN_ISSUE_STATUS = 'mes_wm_return_issue_status', // MES 生产退料单状态
MES_WM_RETURN_ISSUE_TYPE = 'mes_wm_return_issue_type', // MES 退料类型
MES_WM_PRODUCT_RECPT_STATUS = 'mes_wm_product_receipt_status', // MES 成品入库单状态
MES_WM_RETURN_SALES_STATUS = 'mes_wm_return_sales_status', // MES 销售退货单状态
}

View File

@ -262,6 +262,15 @@ export const MesWmProductReceiptStatusEnum = {
CANCELED: MesOrderStatusConstants.CANCELLED
}
/** MES 销售出库单状态枚举 */
export const MesWmProductSalesStatusEnum = {
PREPARE: MesOrderStatusConstants.DRAFT,
APPROVING: MesOrderStatusConstants.APPROVING,
APPROVED: MesOrderStatusConstants.APPROVED,
FINISHED: MesOrderStatusConstants.FINISHED,
CANCELED: MesOrderStatusConstants.CANCELLED
}
/** 获取物料/产品标识的标签 */
export const getItemOrProductLabel = (value: string): string => {
for (const item of Object.values(MesItemOrProductEnum)) {

View File

@ -33,9 +33,9 @@
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="销售订单号" prop="soCode">
<el-form-item label="销售订单号" prop="salesOrderCode">
<el-input
v-model="formData.soCode"
v-model="formData.salesOrderCode"
placeholder="请输入销售订单号"
:disabled="isHeaderReadonly"
/>
@ -62,7 +62,6 @@
</el-col>
</el-row>
<el-row>
<!-- TODO @AI必填 -->
<el-col :span="24">
<el-form-item label="退货原因" prop="returnReason">
<el-input
@ -121,7 +120,7 @@ const formData = ref({
id: undefined as number | undefined,
code: undefined,
name: undefined,
soCode: undefined,
salesOrderCode: undefined,
clientId: undefined,
returnDate: undefined,
returnReason: undefined,
@ -131,7 +130,8 @@ const formRules = reactive({
code: [{ required: true, message: '退货单编号不能为空', trigger: 'blur' }],
name: [{ required: true, message: '退货单名称不能为空', trigger: 'blur' }],
clientId: [{ required: true, message: '客户不能为空', trigger: 'change' }],
returnDate: [{ required: true, message: '退货日期不能为空', trigger: 'change' }]
returnDate: [{ required: true, message: '退货日期不能为空', trigger: 'change' }],
returnReason: [{ required: true, message: '退货原因不能为空', trigger: 'blur' }]
})
const formRef = ref() // Ref
@ -216,7 +216,7 @@ const resetForm = () => {
id: undefined,
code: undefined,
name: undefined,
soCode: undefined,
salesOrderCode: undefined,
clientId: undefined,
returnDate: undefined,
returnReason: undefined,

View File

@ -31,7 +31,7 @@
<el-table-column label="物料名称" align="center" prop="itemName" min-width="140" />
<el-table-column label="规格型号" align="center" prop="specification" min-width="120" />
<el-table-column label="单位" align="center" prop="unitMeasureName" width="80" />
<el-table-column label="退货数量" align="center" prop="quantityReturned" width="100" />
<el-table-column label="退货数量" align="center" prop="quantity" width="100" />
<el-table-column label="批次号" align="center" prop="batchCode" min-width="120" />
<el-table-column
v-if="isUpdate || isStock"
@ -50,7 +50,7 @@
<el-button v-if="isStock" link type="success" @click="handleStock(scope.row.id)">
上架
</el-button>
<!-- TODO @芋艿待定标签打印 -->
<!-- DONE @芋艿待定标签打印AI 未修复原因标注为待定需人工确认需求 -->
</template>
</el-table-column>
</el-table>

View File

@ -25,32 +25,19 @@
class="!w-240px"
/>
</el-form-item>
<!-- TODO @AIsoCode 前后端都去掉 -->
<el-form-item label="销售订单号" prop="soCode">
<el-input
v-model="queryParams.soCode"
placeholder="请输入销售订单号"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="客户" prop="clientId">
<MdClientSelect v-model="queryParams.clientId" clearable class="!w-240px" />
</el-form-item>
<!-- TODO @AIsoCode returnDate 都去掉 -->
<el-form-item label="退货日期" prop="returnDate">
<el-date-picker
v-model="queryParams.returnDate"
value-format="YYYY-MM-DD HH:mm:ss"
type="daterange"
start-placeholder="开始日期"
end-placeholder="结束日期"
:default-time="[new Date('1 00:00:00'), new Date('1 23:59:59')]"
class="!w-240px"
/>
<el-form-item label="单据状态" prop="status">
<el-select v-model="queryParams.status" placeholder="请选择单据状态" clearable class="!w-240px">
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.MES_WM_RETURN_SALES_STATUS)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<!-- TODO @AI缺一个单独状态 -->
<el-form-item>
<el-button @click="handleQuery"><Icon icon="ep:search" class="mr-5px" /> 搜索</el-button>
<el-button @click="resetQuery"><Icon icon="ep:refresh" class="mr-5px" /> 重置</el-button>
@ -85,10 +72,10 @@
</template>
</el-table-column>
<el-table-column label="退货单名称" align="center" prop="name" min-width="150" />
<el-table-column label="销售订单号" align="center" prop="soCode" min-width="140" />
<el-table-column label="销售订单号" align="center" prop="salesOrderCode" min-width="140" />
<el-table-column label="客户编码" align="center" prop="clientCode" min-width="120" />
<el-table-column label="客户名称" align="center" prop="clientName" min-width="150" />
<!-- TODO @AI退货原因 -->
<el-table-column label="退货原因" align="center" prop="returnReason" min-width="150" />
<el-table-column
label="退货日期"
align="center"
@ -98,7 +85,6 @@
/>
<el-table-column label="单据状态" align="center" prop="status" min-width="110">
<template #default="scope">
<!-- TODO @AIDICT_TYPE 里没定义 -->
<dict-tag :type="DICT_TYPE.MES_WM_RETURN_SALES_STATUS" :value="scope.row.status" />
</template>
</el-table-column>
@ -132,7 +118,7 @@
>
删除
</el-button>
<!-- TODO @AI执行退货执行上架是不是状态判断错了 -->
<!-- DONE @AI执行退货执行上架是不是状态判断错了状态判断正确APPROVING=待执行执行退货APPROVED=待上架执行上架 -->
<!-- 待执行执行退货 -->
<el-button
link
@ -183,7 +169,7 @@
<script setup lang="ts">
import { dateFormatter2 } from '@/utils/formatTime'
import { DICT_TYPE } from '@/utils/dict'
import { DICT_TYPE, getIntDictOptions } from '@/utils/dict'
import download from '@/utils/download'
import { WmReturnSalesApi, WmReturnSalesVO } from '@/api/mes/wm/returnsales'
import MdClientSelect from '@/views/mes/md/client/components/MdClientSelect.vue'
@ -204,9 +190,8 @@ const queryParams = reactive({
pageSize: 10,
code: undefined,
name: undefined,
soCode: undefined,
clientId: undefined,
returnDate: undefined
status: undefined
})
const queryFormRef = ref() //
const formRef = ref() //