feat: ftestwork_submit增加抽检逻辑
This commit is contained in:
parent
23dd745192
commit
bfad89bf2f
|
@ -7,36 +7,69 @@ from django.utils import timezone
|
||||||
|
|
||||||
def ftestwork_submit(ins:FtestWork, user: User):
|
def ftestwork_submit(ins:FtestWork, user: User):
|
||||||
wm:WMaterial = ins.wm
|
wm:WMaterial = ins.wm
|
||||||
# 更新对应的车间库存
|
if wm.count_xtest is not None: # 如果关心检验数量 一般是全检
|
||||||
wm.count = wm.count - ins.count
|
# 更新对应的车间库存
|
||||||
if wm.count >= 0:
|
wm.count = wm.count - ins.count
|
||||||
# 已检测的数量
|
if wm.count >= 0:
|
||||||
wm.count_xtest = wm.count_xtest + ins.count
|
# 已检测的数量
|
||||||
wm.save()
|
wm.count_xtest = wm.count_xtest + ins.count
|
||||||
|
wm.save()
|
||||||
|
else:
|
||||||
|
raise ParseError("超过待检数量")
|
||||||
|
# 生成合格的
|
||||||
|
count_ok = ins.count_ok
|
||||||
|
if count_ok > 0:
|
||||||
|
wm, new_create = WMaterial.objects.get_or_create(
|
||||||
|
material=wm.material,
|
||||||
|
batch=wm.batch,
|
||||||
|
mgroup=wm.mgroup,
|
||||||
|
belong_dept=wm.belong_dept,
|
||||||
|
notok_sign=None,
|
||||||
|
material_origin=None,
|
||||||
|
count_xtest=None,
|
||||||
|
defaults={
|
||||||
|
'count': count_ok,
|
||||||
|
'material': wm.material,
|
||||||
|
'batch': wm.batch,
|
||||||
|
'mgroup': wm.mgroup,
|
||||||
|
'belong_dept': wm.belong_dept,
|
||||||
|
}
|
||||||
|
)
|
||||||
|
if not new_create:
|
||||||
|
wm.count = wm.count + count_ok
|
||||||
|
wm.save()
|
||||||
else:
|
else:
|
||||||
raise ParseError("超过待检数量")
|
wm.count = wm.count - ins.count_notok
|
||||||
# 生成合格的
|
if wm.count >= 0:
|
||||||
count_ok = ins.count_ok
|
wm.save()
|
||||||
if count_ok > 0:
|
else:
|
||||||
wm_ok = WMaterial()
|
raise ParseError("不合格数不可大于批次数量")
|
||||||
wm_ok.material = wm.material
|
|
||||||
wm_ok.count = count_ok
|
|
||||||
wm_ok.batch = wm.batch
|
|
||||||
wm_ok.mgroup = wm.mgroup
|
|
||||||
wm_ok.belong_dept = wm.belong_dept
|
|
||||||
wm_ok.save()
|
|
||||||
# 生成不合格的
|
# 生成不合格的
|
||||||
count_notok_json = ins.count_notok_json
|
count_notok_json = ins.count_notok_json
|
||||||
for k, v in count_notok_json.items():
|
for k, v in count_notok_json.items():
|
||||||
if v > 0:
|
if v > 0:
|
||||||
wm_n = WMaterial()
|
notok_sign = k.replace('count_n_', '')
|
||||||
wm_n.material = wm.material
|
wm_n, new_create = WMaterial.objects.get_or_create(
|
||||||
wm_n.count = v
|
material=wm.material,
|
||||||
wm_n.batch = wm.batch
|
batch=wm.batch,
|
||||||
wm_n.mgroup = wm.mgroup
|
mgroup=wm.mgroup,
|
||||||
wm_n.belong_dept = wm.belong_dept
|
belong_dept=wm.belong_dept,
|
||||||
wm_n.notok_sign = k.replace('count_n_', '')
|
notok_sign=notok_sign,
|
||||||
wm_n.save()
|
material_origin=None,
|
||||||
|
count_xtest=None,
|
||||||
|
defaults={
|
||||||
|
'count': v,
|
||||||
|
'material': wm.material,
|
||||||
|
'batch': wm.batch,
|
||||||
|
'mgroup': wm.mgroup,
|
||||||
|
'belong_dept': wm.belong_dept,
|
||||||
|
'notok_sign': notok_sign
|
||||||
|
}
|
||||||
|
)
|
||||||
|
if not new_create:
|
||||||
|
wm_n.count = wm_n.count + v
|
||||||
|
wm_n.save()
|
||||||
ins.submit_user = user
|
ins.submit_user = user
|
||||||
ins.submit_time = timezone.now()
|
ins.submit_time = timezone.now()
|
||||||
ins.save()
|
ins.save()
|
Loading…
Reference in New Issue