mirror of
https://git.v0id.ovh/n3wt-innov/n3wt-school.git
synced 2026-01-29 07:53:23 +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)
|
||||
|
||||
|
||||
Reference in New Issue
Block a user