feat(mes): 优化领料出库拣货明细表单布局,新增库存记录选择

pull/871/MERGE
YunaiV 2026-03-30 10:48:32 +08:00
parent 6c968ac5b7
commit daa269e4ce
1 changed files with 92 additions and 35 deletions

View File

@ -1,6 +1,6 @@
<!-- MES 领料出库拣货明细表单弹窗 --> <!-- MES 领料出库拣货明细表单弹窗 -->
<template> <template>
<Dialog :title="dialogTitle" v-model="dialogVisible" width="600px"> <Dialog :title="dialogTitle" v-model="dialogVisible" width="960px">
<el-form <el-form
ref="formRef" ref="formRef"
:model="formData" :model="formData"
@ -8,33 +8,66 @@
label-width="110px" label-width="110px"
v-loading="formLoading" v-loading="formLoading"
> >
<el-form-item label="物料" prop="itemId"> <el-row>
<MdItemSelect v-model="formData.itemId" disabled /> <el-col :span="8">
</el-form-item> <el-form-item label="物料" prop="itemId">
<el-form-item label="出库仓库" prop="warehouseId"> <MdItemSelect v-model="formData.itemId" disabled />
<WmWarehouseSelect v-model="formData.warehouseId" /> </el-form-item>
</el-form-item> </el-col>
<el-form-item label="库区" prop="locationId" v-if="formData.warehouseId"> <el-col :span="8">
<WmWarehouseLocationSelect <el-form-item label="库存记录" prop="materialStockId">
v-model="formData.locationId" <WmMaterialStockSelect
:warehouse-id="formData.warehouseId" v-model="formData.materialStockId"
/> :item-id="formData.itemId"
</el-form-item> @change="handleStockChange"
<el-form-item label="库位" prop="areaId" v-if="formData.locationId"> />
<WmWarehouseAreaSelect v-model="formData.areaId" :location-id="formData.locationId" /> </el-form-item>
</el-form-item> </el-col>
<el-form-item label="批次号" prop="batchCode"> <el-col :span="8">
<el-input v-model="formData.batchCode" placeholder="请输入批次号" /> <el-form-item label="数量" prop="quantity">
</el-form-item> <el-input-number
<el-form-item label="数量" prop="quantity"> v-model="formData.quantity"
<el-input-number :precision="2"
v-model="formData.quantity" :min="0"
:precision="2" :max="quantityMax"
:min="0" controls-position="right"
controls-position="right" class="!w-1/1"
class="!w-1/1" />
/> </el-form-item>
</el-form-item> </el-col>
</el-row>
<el-row>
<el-col :span="8">
<el-form-item label="出库仓库" prop="warehouseId">
<WmWarehouseSelect v-model="formData.warehouseId" disabled />
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="库区" prop="locationId">
<WmWarehouseLocationSelect
v-model="formData.locationId"
:warehouse-id="formData.warehouseId"
disabled
/>
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="库位" prop="areaId">
<WmWarehouseAreaSelect
v-model="formData.areaId"
:location-id="formData.locationId"
disabled
/>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="8">
<el-form-item label="批次号">
<el-input :model-value="formData.batchCode" disabled />
</el-form-item>
</el-col>
</el-row>
</el-form> </el-form>
<template #footer> <template #footer>
<el-button @click="submitForm" type="primary" :disabled="formLoading"> </el-button> <el-button @click="submitForm" type="primary" :disabled="formLoading"> </el-button>
@ -44,11 +77,10 @@
</template> </template>
<script setup lang="ts"> <script setup lang="ts">
import { import { WmProductIssueDetailApi, WmProductIssueDetailVO } from '@/api/mes/wm/productissue/detail'
WmProductIssueDetailApi, import { WmMaterialStockVO } from '@/api/mes/wm/materialstock'
WmProductIssueDetailVO
} from '@/api/mes/wm/productissue/detail'
import MdItemSelect from '@/views/mes/md/item/components/MdItemSelect.vue' import MdItemSelect from '@/views/mes/md/item/components/MdItemSelect.vue'
import WmMaterialStockSelect from '@/views/mes/wm/materialstock/components/WmMaterialStockSelect.vue'
import WmWarehouseSelect from '@/views/mes/wm/warehouse/components/WmWarehouseSelect.vue' import WmWarehouseSelect from '@/views/mes/wm/warehouse/components/WmWarehouseSelect.vue'
import WmWarehouseLocationSelect from '@/views/mes/wm/warehouse/components/WmWarehouseLocationSelect.vue' import WmWarehouseLocationSelect from '@/views/mes/wm/warehouse/components/WmWarehouseLocationSelect.vue'
import WmWarehouseAreaSelect from '@/views/mes/wm/warehouse/components/WmWarehouseAreaSelect.vue' import WmWarehouseAreaSelect from '@/views/mes/wm/warehouse/components/WmWarehouseAreaSelect.vue'
@ -69,13 +101,16 @@ const dialogTitle = ref('') // 弹窗的标题
const formLoading = ref(false) // const formLoading = ref(false) //
const formType = ref('') // 表单的类型create / update const formType = ref('') // 表单的类型create / update
const currentLineId = ref<number>() // ID const currentLineId = ref<number>() // ID
const quantityMax = ref<number | undefined>(undefined) //
const formRef = ref() // Ref const formRef = ref() // Ref
const formData = ref({ const formData = ref({
id: undefined as number | undefined, id: undefined as number | undefined,
lineId: undefined as number | undefined, lineId: undefined as number | undefined,
issueId: undefined as number | undefined, issueId: undefined as number | undefined,
itemId: undefined as number | undefined, itemId: undefined as number | undefined,
materialStockId: undefined as number | undefined,
quantity: undefined as number | undefined, quantity: undefined as number | undefined,
batchId: undefined as number | undefined,
batchCode: undefined as string | undefined, batchCode: undefined as string | undefined,
warehouseId: undefined as number | undefined, warehouseId: undefined as number | undefined,
locationId: undefined as number | undefined, locationId: undefined as number | undefined,
@ -83,12 +118,31 @@ const formData = ref({
}) })
const formRules = reactive({ const formRules = reactive({
itemId: [{ required: true, message: '物料不能为空', trigger: 'change' }], itemId: [{ required: true, message: '物料不能为空', trigger: 'change' }],
warehouseId: [{ required: true, message: '出库仓库不能为空', trigger: 'change' }], materialStockId: [{ required: true, message: '请选择库存记录', trigger: 'change' }],
locationId: [{ required: true, message: '库区不能为空', trigger: 'change' }],
areaId: [{ required: true, message: '库位不能为空', trigger: 'change' }],
quantity: [{ required: true, message: '数量不能为空', trigger: 'blur' }] quantity: [{ required: true, message: '数量不能为空', trigger: 'blur' }]
}) })
/** 库存选中回调 —— 自动回填仓库/库区/库位/批次/数量 */
const handleStockChange = (stock: WmMaterialStockVO | undefined) => {
if (!stock) {
formData.value.warehouseId = undefined
formData.value.locationId = undefined
formData.value.areaId = undefined
formData.value.batchId = undefined
formData.value.batchCode = undefined
formData.value.quantity = undefined
quantityMax.value = undefined
return
}
formData.value.warehouseId = stock.warehouseId
formData.value.locationId = stock.locationId
formData.value.areaId = stock.areaId
formData.value.batchId = stock.batchId
formData.value.batchCode = stock.batchCode
formData.value.quantity = stock.quantity
quantityMax.value = stock.quantity
}
/** 打开弹窗 */ /** 打开弹窗 */
const open = async (type: string, lineId: number, itemId?: number, detailId?: number) => { const open = async (type: string, lineId: number, itemId?: number, detailId?: number) => {
dialogVisible.value = true dialogVisible.value = true
@ -144,12 +198,15 @@ const resetForm = () => {
lineId: undefined, lineId: undefined,
issueId: undefined, issueId: undefined,
itemId: undefined, itemId: undefined,
materialStockId: undefined,
quantity: undefined, quantity: undefined,
batchId: undefined,
batchCode: undefined, batchCode: undefined,
warehouseId: undefined, warehouseId: undefined,
locationId: undefined, locationId: undefined,
areaId: undefined areaId: undefined
} }
quantityMax.value = undefined
formRef.value?.resetFields() formRef.value?.resetFields()
} }
</script> </script>