| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233 | from rest_framework import viewsetsfrom utils.page import MyPageNumberPaginationfrom utils.md5 import Md5from rest_framework.filters import OrderingFilterfrom django_filters.rest_framework import DjangoFilterBackendfrom rest_framework.response import Responsefrom rest_framework.exceptions import APIExceptionfrom django.http import StreamingHttpResponsefrom stock.models import StockshelfModel as shelflistfrom . import serializersfrom .filter import StockBinFilter,StockshelfFilterfrom .files import FileListRenderCN, FileListRenderEN, FileBinListRenderCN, FileBinListRenderENfrom rest_framework.settings import api_settingsfrom django.db import transaction  from rest_framework import statusclass stockshelfViewSet(viewsets.ModelViewSet):    filter_backends = [DjangoFilterBackend, OrderingFilter, ]    ordering_fields = ['id', "create_time", "update_time", ]    filter_class = StockshelfFilter    pagination_class = MyPageNumberPagination       """        list:            Response a data list(all)        post:            Create a new data(create)    """        def get_project(self):        try:            id = self.kwargs.get('pk')            return id        except:            return None    def get_queryset(self):        id = self.get_project()        if self.request.user:            if id is None:                return shelflist.objects.filter()            else:                return shelflist.objects.filter(id=id)        else:            return shelflist.objects.none()    def get_serializer_class(self):        if self.action in ['list', 'create', ]:            return serializers.stockShelfSerializer        elif self.action in ['retrieve','update',]:            return serializers.stockShelfpartialSerializer        else:            return self.http_method_not_allowed(request=self.request)    def create(self, request, *args, **kwargs):        data = request.data.copy()        warehouse_code = data.get('warehouse_code')        warehouse_name = data.get('warehouse_name')        shelf_type = data.get('shelf_type')        shelf_name = data.get('shelf_name')                rows = int(data.get('rows', 0))        cols = int(data.get('cols', 0))        layers = int(data.get('layers', 0))                existing_positions = shelflist.get_existing_positions(warehouse_code,shelf_name, rows, cols, layers)        # 生成所有可能的坐标        instances = []        for r in range(1, rows+1):            for c in range(1, cols+1):                for l in range(1, layers+1):                    if (r, c, l) not in existing_positions  :                        instances.append(shelflist(                            warehouse_code=warehouse_code,                            warehouse_name=warehouse_name,                            shelf_type=shelf_type,                            shelf_name=shelf_name,                            row=r,                            col=c,                            layer=l,                        ))        try:            with transaction.atomic():                shelflist.objects.bulk_create(instances, batch_size=1000)        except Exception as e:            return Response(                {"error": str(e)},                status=status.HTTP_500_INTERNAL_SERVER_ERROR            )        return Response({            "created": len(instances),            "skipped": (rows*cols*layers) - len(instances)        }, status=status.HTTP_201_CREATED)            def update(self, request, pk):        qs = self.get_object()        print(qs.id)        # return Response({"detail": "暂不支持修改"}, status=status.HTTP_400_BAD_REQUEST)               data = self.request.data        print(data)        serializer = self.get_serializer(qs, data=data)        serializer.is_valid(raise_exception=True)        serializer.save()        headers = self.get_success_headers(serializer.data)        return Response(serializer.data, status=200, headers=headers)    def retrieve(self, request, pk):        qs = self.get_object()        serializer = self.get_serializer(qs)        return Response(serializer.data)class StockBinViewSet(viewsets.ModelViewSet):        filter_backends = [DjangoFilterBackend, OrderingFilter, ]    ordering_fields = ['id', "create_time", "update_time", ]    filter_class = StockBinFilter    pagination_class = MyPageNumberPagination       """        list:            Response a data list(all)        post:            Create a new data(create)    """        def get_project(self):        try:            id = self.kwargs.get('pk')            return id        except:            return None    def get_queryset(self):        id = self.get_project()        if self.request.user:            if id is None:                return shelflist.objects.filter()            else:                return shelflist.objects.filter(id=id)        else:            return shelflist.objects.none()    def get_serializer_class(self):        if self.action in ['list', 'create', ]:            return serializers.stocklistSerializer        # elif self.action in ['retrieve','update',]:        #     return serializers.stocklistpartialSerializer        else:            return self.http_method_not_allowed(request=self.request)    # def create(self, request, *args, **kwargs):    #     data = request.data.copy()    #     warehouse_code = data.get('warehouse_code')    #     warehouse_name = data.get('warehouse_name')    #     shelf_type = data.get('shelf_type')    #     shelf_name = data.get('shelf_name')            #     rows = int(data.get('rows', 0))    #     cols = int(data.get('cols', 0))    #     layers = int(data.get('layers', 0))            #     existing_positions = shelflist.get_existing_positions(warehouse_code,shelf_name, rows, cols, layers)    #     # 生成所有可能的坐标    #     instances = []    #     for r in range(1, rows+1):    #         for c in range(1, cols+1):    #             for l in range(1, layers+1):    #                 if (r, c, l) not in existing_positions  :    #                     instances.append(shelflist(    #                         warehouse_code=warehouse_code,    #                         warehouse_name=warehouse_name,    #                         shelf_type=shelf_type,    #                         shelf_name=shelf_name,    #                         row=r,    #                         col=c,    #                         layer=l,    #                     ))    #     try:    #         with transaction.atomic():    #             shelflist.objects.bulk_create(instances, batch_size=1000)    #     except Exception as e:    #         return Response(    #             {"error": str(e)},    #             status=status.HTTP_500_INTERNAL_SERVER_ERROR    #         )    #     return Response({    #         "created": len(instances),    #         "skipped": (rows*cols*layers) - len(instances)    #     }, status=status.HTTP_201_CREATED)            # def update(self, request, pk):    #     qs = self.get_object()    #     print(qs.id)    #     # return Response({"detail": "暂不支持修改"}, status=status.HTTP_400_BAD_REQUEST)           #     data = self.request.data    #     print(data)    #     serializer = self.get_serializer(qs, data=data)    #     serializer.is_valid(raise_exception=True)    #     serializer.save()    #     headers = self.get_success_headers(serializer.data)    #     return Response(serializer.data, status=200, headers=headers)    # def retrieve(self, request, pk):    #     qs = self.get_object()    #     serializer = self.get_serializer(qs)    #     return Response(serializer.data)
 |