✨ feat(mes): 移除单位编号字段,优化工单 BOM 相关逻辑
parent
1e5f56b54b
commit
39d3efce50
|
|
@ -253,6 +253,7 @@ export enum DICT_TYPE {
|
||||||
IOT_MODBUS_FRAME_FORMAT = 'iot_modbus_frame_format', // IoT Modbus 帧格式
|
IOT_MODBUS_FRAME_FORMAT = 'iot_modbus_frame_format', // IoT Modbus 帧格式
|
||||||
|
|
||||||
// ========== MES - 制造执行系统模块 ==========
|
// ========== MES - 制造执行系统模块 ==========
|
||||||
|
MES_MD_ITEM_OR_PRODUCT = 'mes_md_item_or_product', // MES 物料产品标识
|
||||||
MES_CLIENT_TYPE = 'mes_client_type', // MES 客户类型
|
MES_CLIENT_TYPE = 'mes_client_type', // MES 客户类型
|
||||||
MES_VENDOR_LEVEL = 'mes_vendor_level', // MES 供应商级别
|
MES_VENDOR_LEVEL = 'mes_vendor_level', // MES 供应商级别
|
||||||
MES_CAL_HOLIDAY_TYPE = 'mes_cal_holiday_type', // MES 假期类型
|
MES_CAL_HOLIDAY_TYPE = 'mes_cal_holiday_type', // MES 假期类型
|
||||||
|
|
|
||||||
|
|
@ -7,21 +7,35 @@
|
||||||
<el-table-column label="BOM 物料名称" align="center" prop="itemName" min-width="150" />
|
<el-table-column label="BOM 物料名称" align="center" prop="itemName" min-width="150" />
|
||||||
<el-table-column label="规格型号" align="center" prop="itemSpec" width="120" />
|
<el-table-column label="规格型号" align="center" prop="itemSpec" width="120" />
|
||||||
<el-table-column label="单位" align="center" prop="unitMeasureName" width="80" />
|
<el-table-column label="单位" align="center" prop="unitMeasureName" width="80" />
|
||||||
|
<el-table-column label="物料/产品" align="center" prop="itemOrProduct" width="100">
|
||||||
|
<template #default="scope">
|
||||||
|
<dict-tag :type="DICT_TYPE.MES_MD_ITEM_OR_PRODUCT" :value="scope.row.itemOrProduct" />
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
<el-table-column label="预计使用量" align="center" prop="quantity" width="120" />
|
<el-table-column label="预计使用量" align="center" prop="quantity" width="120" />
|
||||||
<el-table-column label="备注" align="center" prop="remark" min-width="120" />
|
<el-table-column label="备注" align="center" prop="remark" min-width="120" />
|
||||||
<el-table-column label="操作" align="center" width="160" v-if="!disabled">
|
<el-table-column
|
||||||
|
label="操作"
|
||||||
|
align="center"
|
||||||
|
width="160"
|
||||||
|
fixed="right"
|
||||||
|
v-if="
|
||||||
|
[MesProWorkOrderStatusEnum.PREPARE, MesProWorkOrderStatusEnum.CONFIRMED].includes(
|
||||||
|
workOrder.status
|
||||||
|
)
|
||||||
|
"
|
||||||
|
>
|
||||||
<template #default="scope">
|
<template #default="scope">
|
||||||
<!-- 草稿状态:编辑数量/备注 -->
|
<!-- 草稿状态:编辑数量/备注 -->
|
||||||
<!-- TODO @AI:workOrder 来自父组件 WorkOrderForm 通过 prop :work-order="formData" 传入,即当前工单的完整数据 -->
|
|
||||||
<el-button
|
<el-button
|
||||||
v-if="workOrder.status === MesProWorkOrderStatusEnum.PREPARE"
|
v-if="workOrder.status === MesProWorkOrderStatusEnum.PREPARE"
|
||||||
link
|
link
|
||||||
type="primary"
|
type="primary"
|
||||||
@click="openBomForm('update', scope.row)"
|
@click="openForm('update', scope.row)"
|
||||||
>
|
>
|
||||||
编辑
|
编辑
|
||||||
</el-button>
|
</el-button>
|
||||||
<!-- 已确认 + 自行生产 + 产品类型 BOM 行:生成工单 -->
|
<!-- 已确认 + 自行生产 + 产品类型 BOM 行:生成子工单 -->
|
||||||
<el-button
|
<el-button
|
||||||
v-if="
|
v-if="
|
||||||
workOrder.status === MesProWorkOrderStatusEnum.CONFIRMED &&
|
workOrder.status === MesProWorkOrderStatusEnum.CONFIRMED &&
|
||||||
|
|
@ -78,6 +92,7 @@
|
||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { ProWorkOrderBomApi, ProWorkOrderBomVO } from '@/api/mes/pro/workorder/bom'
|
import { ProWorkOrderBomApi, ProWorkOrderBomVO } from '@/api/mes/pro/workorder/bom'
|
||||||
import { MesProWorkOrderStatusEnum, MesProWorkOrderTypeEnum } from '@/views/mes/utils/constants'
|
import { MesProWorkOrderStatusEnum, MesProWorkOrderTypeEnum } from '@/views/mes/utils/constants'
|
||||||
|
import { DICT_TYPE } from '@/utils/dict'
|
||||||
|
|
||||||
defineOptions({ name: 'WorkOrderBomList' })
|
defineOptions({ name: 'WorkOrderBomList' })
|
||||||
|
|
||||||
|
|
@ -116,7 +131,6 @@ const getBomList = async () => {
|
||||||
}
|
}
|
||||||
|
|
||||||
/** 生成工单(通知父组件) */
|
/** 生成工单(通知父组件) */
|
||||||
// todo @芋艿:后续在测试下该逻辑;
|
|
||||||
const handleGenerateWorkOrder = (row: any) => {
|
const handleGenerateWorkOrder = (row: any) => {
|
||||||
emit('generate-work-order', row)
|
emit('generate-work-order', row)
|
||||||
}
|
}
|
||||||
|
|
@ -130,9 +144,6 @@ const formData = ref({
|
||||||
id: undefined as number | undefined,
|
id: undefined as number | undefined,
|
||||||
workOrderId: undefined as number | undefined,
|
workOrderId: undefined as number | undefined,
|
||||||
itemId: undefined as number | undefined,
|
itemId: undefined as number | undefined,
|
||||||
itemName: undefined as string | undefined,
|
|
||||||
unitMeasureId: undefined as number | undefined,
|
|
||||||
unitMeasureName: undefined as string | undefined,
|
|
||||||
quantity: undefined as number | undefined,
|
quantity: undefined as number | undefined,
|
||||||
remark: undefined as string | undefined
|
remark: undefined as string | undefined
|
||||||
})
|
})
|
||||||
|
|
@ -140,20 +151,24 @@ const formRules = reactive({
|
||||||
quantity: [{ required: true, message: '预计使用量不能为空', trigger: 'blur' }]
|
quantity: [{ required: true, message: '预计使用量不能为空', trigger: 'blur' }]
|
||||||
})
|
})
|
||||||
|
|
||||||
|
/** 重置表单 */
|
||||||
|
const resetForm = () => {
|
||||||
|
formData.value = {
|
||||||
|
id: undefined,
|
||||||
|
workOrderId: undefined,
|
||||||
|
itemId: undefined,
|
||||||
|
quantity: undefined,
|
||||||
|
remark: undefined
|
||||||
|
}
|
||||||
|
formRef.value?.resetFields()
|
||||||
|
}
|
||||||
|
|
||||||
/** 打开 BOM 编辑弹窗 */
|
/** 打开 BOM 编辑弹窗 */
|
||||||
const openBomForm = (_type: string, row: any) => {
|
const openForm = (_type: string, row: any) => {
|
||||||
|
resetForm()
|
||||||
dialogVisible.value = true
|
dialogVisible.value = true
|
||||||
dialogTitle.value = '编辑 BOM 物料'
|
dialogTitle.value = '编辑 BOM 物料'
|
||||||
formData.value = {
|
formData.value = { ...row }
|
||||||
id: row.id,
|
|
||||||
workOrderId: row.workOrderId,
|
|
||||||
itemId: row.itemId,
|
|
||||||
itemName: row.itemName,
|
|
||||||
unitMeasureId: row.unitMeasureId,
|
|
||||||
unitMeasureName: row.unitMeasureName,
|
|
||||||
quantity: row.quantity,
|
|
||||||
remark: row.remark
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/** 提交表单 */
|
/** 提交表单 */
|
||||||
|
|
@ -161,14 +176,7 @@ const submitForm = async () => {
|
||||||
await formRef.value.validate()
|
await formRef.value.validate()
|
||||||
formLoading.value = true
|
formLoading.value = true
|
||||||
try {
|
try {
|
||||||
const data = {
|
const data = formData.value as unknown as ProWorkOrderBomVO
|
||||||
id: formData.value.id,
|
|
||||||
workOrderId: formData.value.workOrderId,
|
|
||||||
itemId: formData.value.itemId,
|
|
||||||
unitMeasureId: formData.value.unitMeasureId,
|
|
||||||
quantity: formData.value.quantity,
|
|
||||||
remark: formData.value.remark
|
|
||||||
} as unknown as ProWorkOrderBomVO
|
|
||||||
await ProWorkOrderBomApi.updateWorkOrderBom(data)
|
await ProWorkOrderBomApi.updateWorkOrderBom(data)
|
||||||
message.success(t('common.updateSuccess'))
|
message.success(t('common.updateSuccess'))
|
||||||
dialogVisible.value = false
|
dialogVisible.value = false
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,6 @@
|
||||||
<!-- MES 工单物料需求列表(只读) -->
|
<!-- MES 工单物料需求列表(只读) -->
|
||||||
<template>
|
<template>
|
||||||
<el-table v-loading="loading" :data="itemList" :stripe="true" :show-overflow-tooltip="true">
|
<el-table v-loading="loading" :data="list" :stripe="true" :show-overflow-tooltip="true">
|
||||||
<el-table-column label="物料编码" align="center" prop="itemCode" width="120" />
|
<el-table-column label="物料编码" align="center" prop="itemCode" width="120" />
|
||||||
<el-table-column label="物料名称" align="center" prop="itemName" min-width="150" />
|
<el-table-column label="物料名称" align="center" prop="itemName" min-width="150" />
|
||||||
<el-table-column label="规格型号" align="center" prop="itemSpec" width="120" />
|
<el-table-column label="规格型号" align="center" prop="itemSpec" width="120" />
|
||||||
|
|
@ -18,19 +18,21 @@ const props = defineProps<{
|
||||||
workOrderId: number
|
workOrderId: number
|
||||||
}>()
|
}>()
|
||||||
|
|
||||||
const loading = ref(false)
|
const loading = ref(false) // 列表的加载中
|
||||||
const itemList = ref<any[]>([])
|
const list = ref<any[]>([]) // 列表的数据
|
||||||
|
|
||||||
/** 查询物料需求列表 */
|
/** 查询物料需求列表 */
|
||||||
const getList = async () => {
|
const getList = async () => {
|
||||||
loading.value = true
|
loading.value = true
|
||||||
try {
|
try {
|
||||||
itemList.value = await ProWorkOrderBomApi.getWorkOrderBomItemListByWorkOrderId(props.workOrderId)
|
list.value = await ProWorkOrderBomApi.getWorkOrderBomItemListByWorkOrderId(props.workOrderId)
|
||||||
} finally {
|
} finally {
|
||||||
loading.value = false
|
loading.value = false
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/** 初始化 */
|
/** 初始化 */
|
||||||
onMounted(() => getList())
|
onMounted(() => {
|
||||||
|
getList()
|
||||||
|
})
|
||||||
</script>
|
</script>
|
||||||
|
|
|
||||||
|
|
@ -279,6 +279,9 @@ const handleGenerateWorkOrder = (bomRow: any) => {
|
||||||
formData.value.requestDate = currentWorkOrder.requestDate
|
formData.value.requestDate = currentWorkOrder.requestDate
|
||||||
formData.value.productId = bomRow.itemId
|
formData.value.productId = bomRow.itemId
|
||||||
formData.value.quantity = bomRow.quantity
|
formData.value.quantity = bomRow.quantity
|
||||||
|
formData.value.name = `${bomRow.itemName}【${bomRow.quantity}】${bomRow.unitMeasureName || ''}`
|
||||||
|
// 提示用户
|
||||||
|
message.info('已从 BOM 物料预填子工单,请补充工单编码等信息后保存')
|
||||||
}
|
}
|
||||||
|
|
||||||
defineExpose({ open }) // 提供 open 方法,用于打开弹窗
|
defineExpose({ open }) // 提供 open 方法,用于打开弹窗
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue