1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798 |
- # coding=utf-8
- from rest_framework.views import APIView
- from django.db.models import Q
- from django.utils import timezone
- from rest_framework.decorators import action
- from utils.permission import isLogin, permission_required, check_permission
- from utils.custom_modelviewset import CustomModelViewSet
- from utils import response_ok, response_error
- from utils.exceptions import CustomError
- from apps.log.models import BizLog
- from apps.option.models import Option
- from apps.option.serializers import OptionComboboxSerializer
- from .models import ReportCustomer
- from .serializers import ReportCustomerSerializer
- from .filters import ReportCustomerFilter
- from django.contrib.auth import get_user_model
- User = get_user_model()
- class ReportCustomerViewSet(CustomModelViewSet):
- permission_classes = [isLogin]
- queryset = ReportCustomer.objects.filter()
- serializer_class = ReportCustomerSerializer
- @permission_required('customer.view_report_customer')
- def filter_queryset(self, queryset):
- queryset = queryset.filter(
- Q(store_id__in=self.request.user.get_manager_range()) |
- Q(create_user=self.request.user))
- f = ReportCustomerFilter(self.request.GET, queryset=queryset)
- return f.qs
- @permission_required('customer.add_report_customer')
- def perform_create(self, serializer):
- super(ReportCustomerViewSet, self).perform_create(serializer)
- instance = serializer.instance
- validated_data = serializer.validated_data
- BizLog.objects.addnew(self.request.user, BizLog.INSERT,
- u'添加客户报备[%s],id=%d' % (instance.name, instance.id), validated_data)
- @permission_required('customer.add_report_customer')
- def perform_update(self, serializer):
- super(ReportCustomerViewSet, self).perform_update(serializer)
- instance = serializer.instance
- validated_data = serializer.validated_data
- BizLog.objects.addnew(self.request.user, BizLog.UPDATE,
- u'修改客户报备[%s],id=%d' % (instance.name, instance.id), validated_data)
- @permission_required('customer.delete_report_customer')
- def perform_destroy(self, instance):
- BizLog.objects.addnew(self.request.user, BizLog.DELETE,
- u'删除客户报备[%s],id=%d' % (instance.name, instance.id))
- super(ReportCustomerViewSet, self).perform_destroy(instance)
- @action(methods=['post'], detail=True)
- def dispatch_customer(self, request, pk):
- check_permission(request, 'customer.check_report_customer')
- # 审核
- # TODO 创建潜客跟踪表
- user = request.POST.get('user')
- try:
- instance = ReportCustomer.objects.filter(id=pk).first()
- if not instance:
- raise CustomError('当前客户报备信息有误,请刷新重试!')
- instance.check_user = self.request.user
- instance.report_status = ReportCustomer.CHECKED
- instance.check_time = timezone.now()
- instance.save()
- BizLog.objects.addnew(request.user, BizLog.INSERT,
- u'分配客户报备[%s],id=%d' % (instance.name, instance.id))
- except CustomError as e:
- return response_error(e.get_error_msg())
- except Exception as e:
- return response_error(str(e))
- return response_ok()
- class ReportCustomerDictView(APIView):
- permission_classes = [isLogin]
- def get(self, request):
- scouce = Option.objects.filter(type=Option.CUSTOMER_SOURCE, enable=True)
- project = Option.objects.filter(type=Option.CATEGORY, enable=True)
- serializer_scouce = OptionComboboxSerializer(scouce, many=True)
- serializer_project = OptionComboboxSerializer(project, many=True)
- return response_ok({
- 'source': serializer_scouce.data,
- 'project': serializer_project.data,
- })
- class UserDictView(APIView):
- permission_classes = [isLogin]
- def get(self, request):
- store = request.user.store
- if not store:
- return response_error('当前账号未绑定门店,禁止分配客户!')
- users = User.objects.filter(store=store).values('id', 'name')
- users = [{'value': user['id'], 'lable': user['name']} for user in users]
- return response_ok(users)
|