mirror of
https://git.v0id.ovh/n3wt-innov/n3wt-school.git
synced 2026-01-28 23:43:22 +00:00
feat: Evolution des modèles pour intégrer un planning et du m2m
This commit is contained in:
@ -1,5 +1,8 @@
|
||||
from django.db import models
|
||||
from GestionLogin.models import Profil
|
||||
from django.db.models import JSONField
|
||||
from django.db.models.signals import post_save
|
||||
from django.dispatch import receiver
|
||||
|
||||
class Specialite(models.Model):
|
||||
nom = models.CharField(max_length=100)
|
||||
@ -13,7 +16,7 @@ class Enseignant(models.Model):
|
||||
nom = models.CharField(max_length=100)
|
||||
prenom = models.CharField(max_length=100)
|
||||
mail = models.EmailField(unique=True)
|
||||
specialite = models.ForeignKey(Specialite, on_delete=models.SET_NULL, null=True, blank=True, related_name='enseignants')
|
||||
specialites = models.ManyToManyField(Specialite, related_name='enseignants')
|
||||
profilAssocie = models.ForeignKey(Profil, on_delete=models.CASCADE, null=True, blank=True)
|
||||
|
||||
def __str__(self):
|
||||
@ -26,9 +29,20 @@ class Classe(models.Model):
|
||||
langue_enseignement = models.CharField(max_length=255)
|
||||
annee_scolaire = models.CharField(max_length=9)
|
||||
dateCreation = models.DateTimeField(auto_now_add=True)
|
||||
specialites = models.ManyToManyField(Specialite, related_name='classes')
|
||||
enseignant_principal = models.ForeignKey(Enseignant, on_delete=models.SET_NULL, null=True, blank=True, related_name='classes_principal')
|
||||
|
||||
enseignants = models.ManyToManyField(Enseignant, related_name='classes')
|
||||
|
||||
def __str__(self):
|
||||
return self.nom_ambiance
|
||||
|
||||
class Planning(models.Model):
|
||||
classe = models.OneToOneField(Classe, on_delete=models.SET_NULL, null=True, blank=True, related_name='planning')
|
||||
emploiDuTemps = JSONField(default=list)
|
||||
|
||||
def __str__(self):
|
||||
return f'Planning de {self.classe.nom_ambiance}'
|
||||
|
||||
@receiver(post_save, sender=Classe)
|
||||
def create_planning(sender, instance, created, **kwargs):
|
||||
if created and not hasattr(instance, 'planning'):
|
||||
Planning.objects.create(classe=instance)
|
||||
|
||||
|
||||
@ -1,5 +1,5 @@
|
||||
from rest_framework import serializers
|
||||
from .models import Enseignant, Specialite, Classe
|
||||
from .models import Enseignant, Specialite, Classe, Planning
|
||||
from GestionInscriptions.models import FicheInscription
|
||||
from GestionInscriptions.serializers import EleveSerializer
|
||||
from GestionLogin.serializers import ProfilSerializer
|
||||
@ -21,40 +21,93 @@ class SpecialiteSerializer(serializers.ModelSerializer):
|
||||
|
||||
return local_time.strftime("%d-%m-%Y %H:%M")
|
||||
|
||||
class ClasseSerializer(serializers.ModelSerializer):
|
||||
class EnseignantDetailSerializer(serializers.ModelSerializer):
|
||||
specialites = SpecialiteSerializer(many=True, read_only=True)
|
||||
specialites_ids = serializers.PrimaryKeyRelatedField(queryset=Specialite.objects.all(), many=True, source='specialites')
|
||||
dateCreation_formattee = serializers.SerializerMethodField()
|
||||
enseignant_principal = serializers.SerializerMethodField()
|
||||
enseignant_principal_id = serializers.PrimaryKeyRelatedField(queryset=Enseignant.objects.all(), source='enseignant_principal', write_only=False, read_only=False)
|
||||
eleves = serializers.SerializerMethodField()
|
||||
|
||||
class Meta:
|
||||
model = Classe
|
||||
fields = ['id', 'nom_ambiance', 'tranche_age', 'nombre_eleves', 'langue_enseignement', 'specialites', 'specialites_ids', 'enseignant_principal', 'enseignant_principal_id', 'annee_scolaire', 'dateCreation', 'dateCreation_formattee', 'eleves']
|
||||
model = Enseignant
|
||||
fields = ['id', 'nom', 'prenom', 'mail', 'specialites']
|
||||
|
||||
def get_enseignant_principal(self, obj):
|
||||
from .serializers import EnseignantDetailSerializer
|
||||
if obj.enseignant_principal:
|
||||
return EnseignantDetailSerializer(obj.enseignant_principal).data
|
||||
return None
|
||||
class EnseignantSerializer(serializers.ModelSerializer):
|
||||
specialites = SpecialiteSerializer(many=True, read_only=True)
|
||||
specialites_ids = serializers.PrimaryKeyRelatedField(queryset=Specialite.objects.all(), many=True, source='specialites')
|
||||
profilAssocie_id = serializers.PrimaryKeyRelatedField(queryset=Profil.objects.all(), source='profilAssocie', write_only=False, read_only=False)
|
||||
classes_principal = serializers.PrimaryKeyRelatedField(many=True, read_only=True, source='classes')
|
||||
profilAssocie = ProfilSerializer(read_only=True)
|
||||
DroitLabel = serializers.SerializerMethodField()
|
||||
DroitValue = serializers.SerializerMethodField()
|
||||
|
||||
class Meta:
|
||||
model = Enseignant
|
||||
fields = ['id', 'nom', 'prenom', 'mail', 'specialites', 'specialites_ids', 'classes_principal', 'profilAssocie', 'profilAssocie_id', 'DroitLabel', 'DroitValue']
|
||||
|
||||
def create(self, validated_data):
|
||||
specialites_data = validated_data.pop('specialites', [])
|
||||
classe = Classe.objects.create(**validated_data)
|
||||
classe.specialites.set(specialites_data)
|
||||
return classe
|
||||
specialites_data = validated_data.pop('specialites', None)
|
||||
profilAssocie = validated_data.pop('profilAssocie', None)
|
||||
enseignant = Enseignant.objects.create(**validated_data)
|
||||
enseignant.specialites.set(specialites_data)
|
||||
if profilAssocie:
|
||||
enseignant.profilAssocie = profilAssocie
|
||||
enseignant.save()
|
||||
return enseignant
|
||||
|
||||
def update(self, instance, validated_data):
|
||||
specialites_data = validated_data.pop('specialites', [])
|
||||
instance.nom = validated_data.get('nom', instance.nom)
|
||||
instance.prenom = validated_data.get('prenom', instance.prenom)
|
||||
instance.mail = validated_data.get('mail', instance.mail)
|
||||
instance.profilAssocie = validated_data.get('profilAssocie', instance.profilAssocie)
|
||||
instance.save()
|
||||
instance.specialites.set(specialites_data)
|
||||
return instance
|
||||
|
||||
def get_DroitLabel(self, obj):
|
||||
return obj.profilAssocie.get_droit_display() if obj.profilAssocie else None
|
||||
|
||||
def get_DroitValue(self, obj):
|
||||
return obj.profilAssocie.droit if obj.profilAssocie else None
|
||||
|
||||
class PlanningSerializer(serializers.ModelSerializer):
|
||||
classe_id = serializers.PrimaryKeyRelatedField(queryset=Classe.objects.all(), source='classe')
|
||||
|
||||
class Meta:
|
||||
model = Planning
|
||||
fields = ['id', 'classe', 'classe_id', 'emploiDuTemps']
|
||||
|
||||
class ClasseSerializer(serializers.ModelSerializer):
|
||||
dateCreation_formattee = serializers.SerializerMethodField()
|
||||
enseignants = EnseignantSerializer(many=True, read_only=True)
|
||||
enseignants_ids = serializers.PrimaryKeyRelatedField(queryset=Enseignant.objects.all(), many=True, source='enseignants')
|
||||
eleves = serializers.SerializerMethodField()
|
||||
planning = serializers.SerializerMethodField()
|
||||
|
||||
class Meta:
|
||||
model = Classe
|
||||
fields = ['id', 'nom_ambiance', 'tranche_age', 'nombre_eleves', 'langue_enseignement', 'enseignants', 'enseignants_ids', 'annee_scolaire', 'dateCreation', 'dateCreation_formattee', 'eleves', 'planning']
|
||||
|
||||
def create(self, validated_data):
|
||||
planning_data = validated_data.pop('planning', None)
|
||||
enseignants_data = validated_data.pop('enseignants', [])
|
||||
classe = Classe.objects.create(**validated_data)
|
||||
classe.enseignants.set(enseignants_data)
|
||||
if planning_data and not hasattr(classe, 'planning'):
|
||||
Planning.objects.create(classe=classe, **planning_data)
|
||||
return classe
|
||||
|
||||
def update(self, instance, validated_data):
|
||||
planning_data = validated_data.pop('planning', None)
|
||||
enseignants_data = validated_data.pop('enseignants', [])
|
||||
instance.nom_ambiance = validated_data.get('nom_ambiance', instance.nom_ambiance)
|
||||
instance.tranche_age = validated_data.get('tranche_age', instance.tranche_age)
|
||||
instance.nombre_eleves = validated_data.get('nombre_eleves', instance.nombre_eleves)
|
||||
instance.langue_enseignement = validated_data.get('langue_enseignement', instance.langue_enseignement)
|
||||
instance.annee_scolaire = validated_data.get('annee_scolaire', instance.annee_scolaire)
|
||||
instance.enseignant_principal = validated_data.get('enseignant_principal', instance.enseignant_principal)
|
||||
instance.save()
|
||||
instance.specialites.set(specialites_data)
|
||||
instance.enseignants.set(enseignants_data)
|
||||
if planning_data:
|
||||
planning = instance.planning
|
||||
planning.emploiDuTemps = planning_data.get('emploiDuTemps', planning.emploiDuTemps)
|
||||
planning.save()
|
||||
return instance
|
||||
|
||||
def get_dateCreation_formattee(self, obj):
|
||||
@ -73,39 +126,8 @@ class ClasseSerializer(serializers.ModelSerializer):
|
||||
filtered_eleves.append(eleve)
|
||||
return EleveSerializer(filtered_eleves, many=True, read_only=True).data
|
||||
|
||||
class EnseignantSerializer(serializers.ModelSerializer):
|
||||
specialite = SpecialiteSerializer(read_only=True)
|
||||
specialite_id = serializers.PrimaryKeyRelatedField(queryset=Specialite.objects.all(), source='specialite', write_only=False, read_only=False)
|
||||
profilAssocie_id = serializers.PrimaryKeyRelatedField(queryset=Profil.objects.all(), source='profilAssocie', write_only=False, read_only=False)
|
||||
classes_principal = ClasseSerializer(many=True, read_only=True)
|
||||
profilAssocie = ProfilSerializer(read_only=True)
|
||||
DroitLabel = serializers.SerializerMethodField()
|
||||
DroitValue = serializers.SerializerMethodField()
|
||||
|
||||
class Meta:
|
||||
model = Enseignant
|
||||
fields = ['id', 'nom', 'prenom', 'mail', 'specialite', 'specialite_id', 'classes_principal', 'profilAssocie', 'profilAssocie_id', 'DroitLabel', 'DroitValue']
|
||||
|
||||
def create(self, validated_data):
|
||||
specialite = validated_data.pop('specialite', None)
|
||||
profilAssocie = validated_data.pop('profilAssocie', None)
|
||||
enseignant = Enseignant.objects.create(**validated_data)
|
||||
if specialite:
|
||||
enseignant.specialite = specialite
|
||||
if profilAssocie:
|
||||
enseignant.profilAssocie = profilAssocie
|
||||
enseignant.save()
|
||||
return enseignant
|
||||
|
||||
def get_DroitLabel(self, obj):
|
||||
return obj.profilAssocie.get_droit_display() if obj.profilAssocie else None
|
||||
|
||||
def get_DroitValue(self, obj):
|
||||
return obj.profilAssocie.droit if obj.profilAssocie else None
|
||||
|
||||
class EnseignantDetailSerializer(serializers.ModelSerializer):
|
||||
specialite = SpecialiteSerializer(read_only=True)
|
||||
|
||||
class Meta:
|
||||
model = Enseignant
|
||||
fields = ['id', 'nom', 'prenom', 'mail', 'specialite']
|
||||
def get_planning(self, obj):
|
||||
from .serializers import PlanningSerializer
|
||||
if obj.planning:
|
||||
return PlanningSerializer(obj.planning).data
|
||||
return None
|
||||
|
||||
@ -81,6 +81,8 @@ class SpecialitesView(APIView):
|
||||
specialitesList = bdd.getAllObjects(Specialite)
|
||||
specialites_serializer = SpecialiteSerializer(specialitesList, many=True)
|
||||
|
||||
return JsonResponse(specialites_serializer.data, safe=False)
|
||||
|
||||
return JsonResponse(specialite_serializer.errors, safe=False)
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user