fix: mlogbw create 调换一下if顺序

This commit is contained in:
caoqianming 2025-08-25 09:44:32 +08:00
parent 4823acb004
commit 0a6959a36c
1 changed files with 16 additions and 11 deletions

View File

@ -893,15 +893,28 @@ class MlogbwViewSet(CustomModelViewSet):
if mlog != ins.mlogb.mlog:
raise ParseError("所有记录必须属于同一张日志")
mlogb:Mlogb = ins.mlogb
route:Route = mlogb.route
route:Route = mlogb.route if mlogb.route else mlog.route
Mlogbw.cal_count_notok(mlogb)
# 如果是输入且输出追踪到个,需同步创建
material_in:Material = mlogb.material_in
if material_in is not None:
mlogb_qs = Mlogb.objects.filter(mlogb_from=mlogb)
material_out:Material = route.material_out if route else material_in if mlog.is_fix is False else mlog.material_out
if route:
material_out = route.material_out
elif mlog.is_fix:
material_out = material_in
else:
raise ParseError("获取产出物料错误")
mtype = route.process.mtype if route.process else None
if mtype == Process.PRO_DIV:
if mlogb_qs.exists() and material_out.tracking == Material.MA_TRACKING_SINGLE:
for mlogb in mlogb_qs:
if route.process.mtype == Process.PRO_NORMAL:
Mlogbw.objects.get_or_create(mlogb=mlogb, wpr=ins.wpr, defaults={"number": ins.number, "mlogbw_from": ins})
elif route.process.mtype == Process.PRO_DIV:
for i in range(route.div_number):
Mlogbw.objects.get_or_create(mlogb=mlogb, number=f'{ins.number}-{i+1}', defaults={"mlogbw_from": ins})
Mlogbw.cal_count_notok(mlogb)
elif mtype == Process.PRO_DIV:
mlogbin = ins.mlogb
wm_in = mlogbin.wm_in
mlog = mlogbin.mlog
@ -930,14 +943,6 @@ class MlogbwViewSet(CustomModelViewSet):
pass
else:
raise ParseError("该个号不可产生该批")
elif mlogb_qs.exists() and material_out.tracking == Material.MA_TRACKING_SINGLE:
for mlogb in mlogb_qs:
if route.process.mtype == Process.PRO_NORMAL:
Mlogbw.objects.get_or_create(mlogb=mlogb, wpr=ins.wpr, defaults={"number": ins.number, "mlogbw_from": ins})
elif route.process.mtype == Process.PRO_DIV:
for i in range(route.div_number):
Mlogbw.objects.get_or_create(mlogb=mlogb, number=f'{ins.number}-{i+1}', defaults={"mlogbw_from": ins})
Mlogbw.cal_count_notok(mlogb)
mlog.cal_mlog_count_from_mlogb()
@transaction.atomic