Merge branch 'master' of https://e.coding.net/ctcdevteam/cma_search
This commit is contained in:
commit
b59cf78c4e
|
|
@ -0,0 +1,18 @@
|
||||||
|
# Generated by Django 3.0.5 on 2022-06-07 01:00
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('ability', '0034_quali_file'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.AlterField(
|
||||||
|
model_name='qaction',
|
||||||
|
name='action',
|
||||||
|
field=models.CharField(choices=[('service:update', '更新服务'), ('quali:create', '新增资质'), ('quali:update', '更新资质'), ('ablity:create', '新增能力'), ('ablity:nochange', '能力无变化'), ('quali:nochange', '资质无变化')], max_length=20, verbose_name='操作类型'),
|
||||||
|
),
|
||||||
|
]
|
||||||
|
|
@ -198,6 +198,8 @@ class QAction(CommonBModel):
|
||||||
('quali:create', '新增资质'),
|
('quali:create', '新增资质'),
|
||||||
('quali:update', '更新资质'),
|
('quali:update', '更新资质'),
|
||||||
('ablity:create', '新增能力'),
|
('ablity:create', '新增能力'),
|
||||||
|
('ablity:nochange', '能力无变化'),
|
||||||
|
('quali:nochange', '资质无变化')
|
||||||
)
|
)
|
||||||
action = models.CharField('操作类型', max_length=20, choices=QACTION_CHOICE)
|
action = models.CharField('操作类型', max_length=20, choices=QACTION_CHOICE)
|
||||||
quali = models.ForeignKey(Quali, null=True, blank=True, verbose_name='操作资质', on_delete=models.CASCADE)
|
quali = models.ForeignKey(Quali, null=True, blank=True, verbose_name='操作资质', on_delete=models.CASCADE)
|
||||||
|
|
|
||||||
|
|
@ -146,6 +146,11 @@ class QActionQualiUpdateSerializer(serializers.ModelSerializer):
|
||||||
validated_data['value2'] = self.data['value2']
|
validated_data['value2'] = self.data['value2']
|
||||||
return super().create(validated_data)
|
return super().create(validated_data)
|
||||||
|
|
||||||
|
class QActionNoChangeSerializer(serializers.ModelSerializer):
|
||||||
|
class Meta:
|
||||||
|
model = QAction
|
||||||
|
fields = ['qtask']
|
||||||
|
|
||||||
class QActionACreateSerializer(serializers.ModelSerializer):
|
class QActionACreateSerializer(serializers.ModelSerializer):
|
||||||
class Meta:
|
class Meta:
|
||||||
model = QAction
|
model = QAction
|
||||||
|
|
|
||||||
|
|
@ -2,7 +2,7 @@ from rest_framework.viewsets import GenericViewSet
|
||||||
from rest_framework.mixins import ListModelMixin, RetrieveModelMixin, CreateModelMixin, UpdateModelMixin, DestroyModelMixin, RetrieveModelMixin
|
from rest_framework.mixins import ListModelMixin, RetrieveModelMixin, CreateModelMixin, UpdateModelMixin, DestroyModelMixin, RetrieveModelMixin
|
||||||
from rest_framework.decorators import action
|
from rest_framework.decorators import action
|
||||||
from apps.ability.models import QAction, QActionItem, QOrg, QTask, Quali, QualiLib
|
from apps.ability.models import QAction, QActionItem, QOrg, QTask, Quali, QualiLib
|
||||||
from apps.ability.serializers_qtask import QActionACreateSerializer, QActionDetailSerializer, QActionListSerializer, QActionQualiCreateSerializer, QActionQualiUpdateSerializer, QActionServiceSerializer, QOrgListSerializer, QTaskCreateUpdateSerializer, QTaskListSerializer, QualiCreateSerializer, QualiLibListSerializer, QualiListSerializer, QualiSerializer, QualiUpdateSerializer
|
from apps.ability.serializers_qtask import QActionACreateSerializer, QActionDetailSerializer, QActionListSerializer, QActionNoChangeSerializer, QActionQualiCreateSerializer, QActionQualiUpdateSerializer, QActionServiceSerializer, QOrgListSerializer, QTaskCreateUpdateSerializer, QTaskListSerializer, QualiCreateSerializer, QualiLibListSerializer, QualiListSerializer, QualiSerializer, QualiUpdateSerializer
|
||||||
from django.db import transaction
|
from django.db import transaction
|
||||||
from rest_framework.response import Response
|
from rest_framework.response import Response
|
||||||
from rest_framework import status
|
from rest_framework import status
|
||||||
|
|
@ -99,7 +99,7 @@ def cal_count(qtask, org):
|
||||||
qorg.save()
|
qorg.save()
|
||||||
|
|
||||||
class QActionViewSet(PageOrNot, ListModelMixin, DestroyModelMixin, RetrieveModelMixin,GenericViewSet):
|
class QActionViewSet(PageOrNot, ListModelMixin, DestroyModelMixin, RetrieveModelMixin,GenericViewSet):
|
||||||
perms_map = {'get': 'qtask_view', 'delete': 'qaction_delete'}
|
perms_map = {'get': '*', 'delete': 'qaction_delete'}
|
||||||
queryset = QAction.objects.select_related('file', 'atype', 'afield', 'qtask', 'belong_dept', 'create_by')
|
queryset = QAction.objects.select_related('file', 'atype', 'afield', 'qtask', 'belong_dept', 'create_by')
|
||||||
filterset_fields = ['qtask', 'belong_dept', 'atype', 'afield']
|
filterset_fields = ['qtask', 'belong_dept', 'atype', 'afield']
|
||||||
serializer_class = QActionListSerializer
|
serializer_class = QActionListSerializer
|
||||||
|
|
@ -198,7 +198,7 @@ class QActionViewSet(PageOrNot, ListModelMixin, DestroyModelMixin, RetrieveModel
|
||||||
return Response()
|
return Response()
|
||||||
|
|
||||||
@action(methods=['post'], detail=False,
|
@action(methods=['post'], detail=False,
|
||||||
perms_map = {'post':'ability_create'}, serializer_class=QActionACreateSerializer)
|
perms_map = {'post':'qaction_create'}, serializer_class=QActionACreateSerializer)
|
||||||
@transaction.atomic
|
@transaction.atomic
|
||||||
def ability_create(self, request, *args, **kwargs):
|
def ability_create(self, request, *args, **kwargs):
|
||||||
"""
|
"""
|
||||||
|
|
@ -212,6 +212,37 @@ class QActionViewSet(PageOrNot, ListModelMixin, DestroyModelMixin, RetrieveModel
|
||||||
cal_count(vdata['qtask'], user.dept)
|
cal_count(vdata['qtask'], user.dept)
|
||||||
return Response()
|
return Response()
|
||||||
|
|
||||||
|
@action(methods=['post'], detail=False,
|
||||||
|
perms_map = {'post':'qaction_create'}, serializer_class=QActionNoChangeSerializer)
|
||||||
|
@transaction.atomic
|
||||||
|
def ability_nochange(self, request, *args, **kwargs):
|
||||||
|
"""
|
||||||
|
能力无变化
|
||||||
|
"""
|
||||||
|
user = request.user
|
||||||
|
serializer = self.get_serializer(data=request.data)
|
||||||
|
serializer.is_valid(raise_exception=True)
|
||||||
|
serializer.save(create_by=user, belong_dept=user.dept, action='ability:nochange')
|
||||||
|
vdata = serializer.validated_data
|
||||||
|
cal_count(vdata['qtask'], user.dept)
|
||||||
|
return Response()
|
||||||
|
|
||||||
|
@action(methods=['post'], detail=False,
|
||||||
|
perms_map = {'post':'qaction_create'}, serializer_class=QActionNoChangeSerializer)
|
||||||
|
@transaction.atomic
|
||||||
|
def quali_nochange(self, request, *args, **kwargs):
|
||||||
|
"""
|
||||||
|
资质无变化
|
||||||
|
"""
|
||||||
|
user = request.user
|
||||||
|
serializer = self.get_serializer(data=request.data)
|
||||||
|
serializer.is_valid(raise_exception=True)
|
||||||
|
serializer.save(create_by=user, belong_dept=user.dept, action='quali:nochange')
|
||||||
|
vdata = serializer.validated_data
|
||||||
|
cal_count(vdata['qtask'], user.dept)
|
||||||
|
return Response()
|
||||||
|
|
||||||
|
|
||||||
@action(methods=['put'], detail=True, perms_map = {'put':'qaction_confirm'},
|
@action(methods=['put'], detail=True, perms_map = {'put':'qaction_confirm'},
|
||||||
serializer_class=serializers.Serializer)
|
serializer_class=serializers.Serializer)
|
||||||
@transaction.atomic
|
@transaction.atomic
|
||||||
|
|
|
||||||
|
|
@ -378,25 +378,28 @@ class UserViewSet(PageOrNot, ModelViewSet):
|
||||||
i = 3
|
i = 3
|
||||||
role1 = Role.objects.get(name='能力查询')
|
role1 = Role.objects.get(name='能力查询')
|
||||||
role2 = Role.objects.get(name='资质能力报送')
|
role2 = Role.objects.get(name='资质能力报送')
|
||||||
role3 = Role.objects.get(name='资料分享和视频培训')
|
role3 = Role.objects.get(name='资料分享')
|
||||||
|
role4 = Role.objects.get(name='视频培训')
|
||||||
while sheet['b'+str(i)].value:
|
while sheet['b'+str(i)].value:
|
||||||
name = sheet['b'+str(i)].value
|
name = sheet['b'+str(i)].value
|
||||||
email = sheet['e'+str(i)].value
|
email = sheet['e'+str(i)].value
|
||||||
if not User.objects.filter(username=email).exists():
|
if not User.objects.filter(username=email).exists():
|
||||||
dept = Organization.objects.get(name=sheet['j'+str(i)].value)
|
|
||||||
user = User.objects.create(name=name,
|
user = User.objects.create(name=name,
|
||||||
username=email,
|
username=email,
|
||||||
password=make_password(''.join(random.sample(string.ascii_letters + string.digits, 8))),
|
password=make_password(''.join(random.sample(string.ascii_letters + string.digits, 8))),
|
||||||
dept=dept)
|
dept=dept)
|
||||||
if sheet['f'+str(i)].value:
|
|
||||||
user.roles.add(role1)
|
|
||||||
if sheet['g'+str(i)].value:
|
|
||||||
user.roles.add(role2)
|
|
||||||
if sheet['h'+str(i)].value:
|
|
||||||
user.roles.add(role3)
|
|
||||||
print(str(i)+name+'已导入')
|
|
||||||
else:
|
else:
|
||||||
print(str(i)+name+'已存在')
|
user = User.objects.get(username=email)
|
||||||
|
dept = Organization.objects.get(name=sheet['j'+str(i)].value)
|
||||||
|
if sheet['f'+str(i)].value:
|
||||||
|
user.roles.add(role1)
|
||||||
|
if sheet['g'+str(i)].value:
|
||||||
|
user.roles.add(role2)
|
||||||
|
if sheet['h'+str(i)].value:
|
||||||
|
user.roles.add(role3)
|
||||||
|
if sheet['i'+str(i)].value:
|
||||||
|
user.roles.add(role4)
|
||||||
|
print(str(i)+name+'已导入')
|
||||||
i = i + 1
|
i = i + 1
|
||||||
return Response()
|
return Response()
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -48,8 +48,8 @@ class VideoViewSet(PageOrNot, CreateUpdateModelAMixin, ModelViewSet):
|
||||||
search_fields = ['name', 'category__name', 'description']
|
search_fields = ['name', 'category__name', 'description']
|
||||||
# filterset_fields = ['category']
|
# filterset_fields = ['category']
|
||||||
serializer_class = VideoSerializer
|
serializer_class = VideoSerializer
|
||||||
ordering_fields = ['category__sort', 'sort_str', 'views', 'viewsp']
|
ordering_fields = ['category__code', 'sort_str', 'views', 'viewsp']
|
||||||
ordering = ['category__sort', 'sort_str']
|
ordering = ['category__code', 'sort_str']
|
||||||
|
|
||||||
def get_serializer_class(self):
|
def get_serializer_class(self):
|
||||||
if self.action in ['list', 'retrieve']:
|
if self.action in ['list', 'retrieve']:
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue