123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990 |
- # coding=utf-8
- from django.db import transaction
- from rest_framework import generics
- from rest_framework.decorators import action
- from utils import response_ok, response_error
- from utils.custom_modelviewset import CustomModelViewSet
- from utils.exceptions import CustomError
- from utils.permission import IsTenantUser, isLogin
- from apps.tenant.inspection_order.models import InspectionOrder
- from apps.tenant.inspection_order.filters import InspectionOrderFilter
- from apps.upload.models import Upload
- from .serializers import InspectionOrderSerializer, InspectionOrderListSerializer,InspectionOrderDetailSerializer
- from apps.log.models import BizLog
- from apps.tenant import tenant_log
- class InspectionOrderDetailView(generics.RetrieveAPIView):
- # 检修工单详情,已不用。
- permission_classes = [isLogin, ]
- queryset = InspectionOrder.objects.filter()
- serializer_class = InspectionOrderDetailSerializer
- def retrieve(self, request, *args, **kwargs):
- instance = self.get_object()
- serializer = self.get_serializer(instance)
- return response_ok(serializer.data)
- def filter_queryset(self, queryset):
- # queryset = queryset.filter(tenant=self.request.user.employee.tenant, user=self.request.user)
- f = InspectionOrderFilter(self.request.GET, queryset=queryset)
- return f.qs
- class InspectionOrderAllView(generics.ListAPIView):
- permission_classes = [isLogin, ]
- queryset = InspectionOrder.objects.filter()
- serializer_class = InspectionOrderListSerializer
- def filter_queryset(self, queryset):
- queryset = queryset.filter(tenant=self.request.user.employee.tenant)
- f = InspectionOrderFilter(self.request.GET, queryset=queryset)
- return f.qs
- class InspectionOrderViewSet(CustomModelViewSet):
- permission_classes = [isLogin, ]
- queryset = InspectionOrder.objects.filter()
- serializer_class = InspectionOrderSerializer
- def filter_queryset(self, queryset):
- queryset = queryset.filter(tenant=self.request.user.employee.tenant, user=self.request.user)
- f = InspectionOrderFilter(self.request.GET, queryset=queryset)
- return f.qs
- def retrieve(self, request, *args, **kwargs):
- # 巡检工单详情
- instance = self.get_object()
- serializer = InspectionOrderDetailSerializer(instance)
- return response_ok(serializer.data)
- def perform_create(self, serializer):
- super(InspectionOrderViewSet, self).perform_create(serializer)
- instance = serializer.instance
- validated_data = serializer.validated_data
- tenant_log(self.request.user.employee, BizLog.INSERT, u'添加巡检[%s],id=%d' % (instance.no, instance.id),
- validated_data)
- @action(methods=['get'], detail=True)
- def turn_repair(self, request, pk):
- # 转报修
- try:
- if not self.request.user.is_employee():
- raise CustomError(u"权限不足,禁止操作!")
- with transaction.atomic():
- user = self.request.user
- instance = InspectionOrder.get_instance_by_id(pk, user.employee.tenant)
- instance.turn_repair(user)
- except CustomError as e:
- return response_error(e.get_error_msg())
- except Exception as e:
- return response_error(str(e))
- return response_ok('转报修完成!')
- @action(methods=['post'], detail=False)
- def upload_image(self, request):
- file = self.request.FILES.get('file')
- user = self.request.user
- upload = Upload.objects._addnew(user.employee.tenant, user, Upload.INSPECTION_IMAGE, file)
- if upload:
- return response_ok(upload.id)
- return response_error('上传失败,请重新上传!')
|