feat: wm 增加 来料/完成 筛选

This commit is contained in:
caoqianming 2025-03-06 16:15:08 +08:00
parent 4f60483a49
commit f7843621df
1 changed files with 14 additions and 0 deletions

View File

@ -36,6 +36,7 @@ class StLogFilter(filters.FilterSet):
class WMaterialFilter(filters.FilterSet):
mgroupx = filters.CharFilter(label='MgroupId', method='filter_mgroupx')
tag = filters.CharFilter(label="todo/done", method="filter_tag")
mtaskx = filters.CharFilter(label='MtaskId', method='filter_mtaskx')
route = filters.CharFilter(label='routeId', method='filter_route')
material__process__exclude = filters.CharFilter(field_name="material__process", lookup_expr="exact", exclude=True)
@ -43,6 +44,19 @@ class WMaterialFilter(filters.FilterSet):
def filter_mgroupx(self, queryset, name, value):
return queryset.filter(mgroup__id=value)|queryset.filter(belong_dept=Mgroup.objects.get(id=value).belong_dept, mgroup=None)
def filter_tag(self, queryset, name, value):
mgroup = self.data.get("mgroupx", None)
if mgroup:
process = Mgroup.objects.get(id=mgroup).process
if value == "todo":
qs = queryset.filter(material__process=process)|queryset.filter(state=WMaterial.WM_REPAIR)
return qs
elif value == "done":
qs = queryset.exclude(material__process=process)|queryset.filter(state=WMaterial.WM_REPAIRED)
return qs
else:
raise ParseError("请提供工段查询条件")
def filter_mtaskx(self, queryset, name, value):
mtask = Mtask.objects.get(id=value)
if mtask.route and mtask.route.batch_bind: