feat: wpr增加can_use筛选条件

This commit is contained in:
caoqianming 2025-08-07 09:31:53 +08:00
parent 925666d3ef
commit aa72953d17
2 changed files with 34 additions and 8 deletions

32
apps/wpmw/filters.py Normal file
View File

@ -0,0 +1,32 @@
from django_filters import rest_framework as filters
from apps.wpm.models import (Handoverbw, Mlogbw)
from apps.inm.models import MIOItemw
from apps.wpmw.models import Wpr
from apps.mtm.models import Route, Material
from django.db.models import Q
from rest_framework.exceptions import ParseError
class WprFilter(filters.FilterSet):
can_use = filters.CharFilter(method='filter_can_use')
class Meta:
model = Wpr
fields = {
"mb": ["exact", "isnull"],
"wm": ["exact", "isnull"],
"material__process": ["exact"],
"state": ["exact"],
"defects": ["exact"],
"number": ["exact"]
}
def filter_can_use(self, queryset, name, value):
if value == 'yes':
# 交接记录
handoverws = Handoverbw.objects.filter(handoverb__handover__submit_time__isnull=True).values_list('wpr__id', flat=True)
# 生产日志
mlogbws = Mlogbw.objects.filter(mlogb__mlog__submit_time__isnull=True).values_list('wpr__id', flat=True)
# 出入库记录
mioitemws = MIOItemw.objects.filter(mioitem__mio__submit_time__isnull=True).values_list('wpr__id', flat=True)
return queryset.exclude(id__in=handoverws).exclude(id__in=mlogbws).exclude(id__in=mioitemws)
return queryset

View File

@ -8,6 +8,7 @@ from rest_framework.response import Response
from apps.mtm.models import Material
from rest_framework.exceptions import ParseError
from django.db import transaction
from apps.wpmw.filters import WprFilter
class WprViewSet(CustomListModelMixin, RetrieveModelMixin, ComplexQueryMixin, CustomGenericViewSet):
@ -21,14 +22,7 @@ class WprViewSet(CustomListModelMixin, RetrieveModelMixin, ComplexQueryMixin, Cu
queryset = Wpr.objects.all()
serializer_class = WprSerializer
retrieve_serializer_class = WprDetailSerializer
filterset_fields = {
"mb": ["exact", "isnull"],
"wm": ["exact", "isnull"],
"material__process": ["exact"],
"state": ["exact"],
"defects": ["exact"],
"number": ["exact"]
}
filterset_class = WprFilter
ordering = ["number", "create_time"]
ordering_fields = ["number", "create_time", "update_time"]
search_fields = ["number", "material__name", "material__model", "material__specification", "number_out"]