# 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)