|
|
|
|
@ -1,6 +1,7 @@ |
|
|
|
|
from django.contrib.auth import get_user_model |
|
|
|
|
from rest_framework import serializers |
|
|
|
|
from access.models.other import Account, Progress |
|
|
|
|
from achievements.serialers import DiplomaSerializer, AchievementsSerializer |
|
|
|
|
from courses.serializers import MiniVertexSerializer, CourseInitSerializer |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -24,12 +25,15 @@ class ProgressSerializer(serializers.ModelSerializer): |
|
|
|
|
|
|
|
|
|
@staticmethod |
|
|
|
|
def get_in_progress(self): |
|
|
|
|
return [MiniVertexSerializer(i).data for i in self.get_objects_in_progress()] |
|
|
|
|
if self.is_finish(): |
|
|
|
|
return [] |
|
|
|
|
else: |
|
|
|
|
return [MiniVertexSerializer(i).data for i in self.get_objects_in_progress()] |
|
|
|
|
|
|
|
|
|
@staticmethod |
|
|
|
|
def get_number(self): |
|
|
|
|
if self.is_finish(): |
|
|
|
|
return self.get_max() |
|
|
|
|
return self.course.get_vertexes('topic').count() |
|
|
|
|
return self.progress_list.filter(content_type__model="topic").count() |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -38,7 +42,7 @@ class AccountSerializer(serializers.ModelSerializer): |
|
|
|
|
|
|
|
|
|
class Meta: |
|
|
|
|
model = Account |
|
|
|
|
exclude = ('owner', 'id', ) |
|
|
|
|
exclude = ('owner', 'id',) |
|
|
|
|
|
|
|
|
|
@staticmethod |
|
|
|
|
def get_gender(self): |
|
|
|
|
@ -49,11 +53,21 @@ class UserSelfSerializer(serializers.ModelSerializer): |
|
|
|
|
account = serializers.SerializerMethodField() |
|
|
|
|
groups = serializers.SerializerMethodField() |
|
|
|
|
progress = serializers.SerializerMethodField() |
|
|
|
|
diplomas = serializers.SerializerMethodField() |
|
|
|
|
achievements = serializers.SerializerMethodField() |
|
|
|
|
|
|
|
|
|
class Meta: |
|
|
|
|
model = get_user_model() |
|
|
|
|
fields = ('id', 'email', 'first_name', 'last_name','progress', |
|
|
|
|
'account', 'groups', 'is_staff', 'is_superuser') |
|
|
|
|
fields = ('id', 'email', 'first_name', 'last_name', 'progress', 'achievements', |
|
|
|
|
'account', 'groups', 'is_staff', 'is_superuser', 'diplomas') |
|
|
|
|
|
|
|
|
|
@staticmethod |
|
|
|
|
def get_diplomas(self): |
|
|
|
|
return [DiplomaSerializer(i).data for i in self.diploma_set.all()] |
|
|
|
|
|
|
|
|
|
@staticmethod |
|
|
|
|
def get_achievements(self): |
|
|
|
|
return [AchievementsSerializer(i).data for i in self.achievements_set.all()] |
|
|
|
|
|
|
|
|
|
@staticmethod |
|
|
|
|
def get_account(self): |
|
|
|
|
@ -102,4 +116,4 @@ class UserSearchSerializer(serializers.ModelSerializer): |
|
|
|
|
|
|
|
|
|
@staticmethod |
|
|
|
|
def get_pay(self): |
|
|
|
|
return sum([i.get_full_price() for i in self.bill_user.all()]) |
|
|
|
|
return sum([i.get_full_price() for i in self.bill_user.all()]) |
|
|
|
|
|