views.py 3.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. # coding=utf-8
  2. from rest_framework.views import APIView
  3. from django.db import transaction
  4. from utils import response_ok, response_error
  5. from utils.custom_modelviewset import CustomModelViewSet
  6. from utils.permission import IsTenantUser, IsAdministratorUser
  7. from apps.tenant.employee.models import Employee
  8. from apps.tenant import tenant_log
  9. from apps.log.models import BizLog
  10. from apps.tenant.employee.filters import EmployeeFilter
  11. from .serializers import EmployeeSerializer
  12. from rest_framework.decorators import action
  13. from utils.exceptions import CustomError
  14. class DictView(APIView):
  15. permission_classes = [IsTenantUser, ]
  16. def get(self, request):
  17. ret = {
  18. 'status': Employee.STATUS_CHOICES, # 职工状态
  19. 'emp_types': Employee.TYPE_CHOICES, # 职工角色
  20. }
  21. return response_ok(ret)
  22. class VisitorView(CustomModelViewSet):
  23. permission_classes = [IsTenantUser]
  24. queryset = Employee.objects.filter()
  25. serializer_class = EmployeeSerializer
  26. def filter_queryset(self, queryset):
  27. queryset = queryset.filter(tenant=self.request.user.employee.tenant, type=Employee.REPAIR)
  28. f = EmployeeFilter(self.request.GET, queryset=queryset)
  29. return f.qs
  30. @action(methods=['post'], detail=True)
  31. def forbid_baoxiu(self, request, pk):
  32. forbid_baoxiu = request.POST.get('forbid_baoxiu')
  33. instance = Employee.objects.filter(id=pk).first()
  34. if instance:
  35. instance.status = 4 if forbid_baoxiu == '1' else 1
  36. instance.save()
  37. else:
  38. return response_error(u'报修人信息有误,请刷新重试。')
  39. return response_ok()
  40. class EmployeeViewSet(CustomModelViewSet):
  41. permission_classes = [IsAdministratorUser]
  42. queryset = Employee.objects.filter()
  43. serializer_class = EmployeeSerializer
  44. def filter_queryset(self, queryset):
  45. queryset = queryset.filter(tenant=self.request.user.employee.tenant)
  46. f = EmployeeFilter(self.request.GET, queryset=queryset)
  47. return f.qs
  48. def perform_create(self, serializer):
  49. super(EmployeeViewSet, self).perform_create(serializer)
  50. instance = serializer.instance
  51. validated_data = serializer.validated_data
  52. tenant_log(self.request.user.employee, BizLog.INSERT, u'添加人员[%s],id=%d' % (instance.name, instance.id),
  53. validated_data)
  54. def perform_update(self, serializer):
  55. super(EmployeeViewSet, self).perform_update(serializer)
  56. instance = serializer.instance
  57. validated_data = serializer.validated_data
  58. tenant_log(self.request.user.employee, BizLog.UPDATE, u'修改人员[%s],id=%d' % (instance.name, instance.id),
  59. validated_data)
  60. def destroy(self, request, *args, **kwargs):
  61. with transaction.atomic():
  62. instance = self.get_object()
  63. if instance.tenant != request.user.employee.tenant:
  64. raise CustomError(u'禁止跨企业操作!')
  65. super(EmployeeViewSet, self).destroy(self, request, *args, **kwargs)
  66. tenant_log(self.request.user.employee, BizLog.DELETE, u'删除人员[%s],id=%d' % (instance.name, instance.id))
  67. return response_ok()