InfoTech-Backend/infotech/schedules/models.py

49 lines
1.5 KiB
Python
Raw Normal View History

from django.db import models
from django.utils.timezone import now
# Create your models here.
class Schedule(models.Model):
2023-04-22 14:14:53 +08:00
name = models.TextField()
subject = models.ForeignKey('subjects.Subject', on_delete=models.CASCADE)
students_assigned = models.ManyToManyField(
'students.Student', related_name='StudentSchedule_student_assigned', through='schedules.StudentSchedule')
professor = models.OneToOneField(
'professors.Professor', related_name='Professor_full_name', on_delete=models.CASCADE)
2023-04-22 14:07:08 +08:00
# daytimes = models.ForeignKey(
# 'daytimes.DayTime', related_name='DayTime_full_name', on_delete=models.CASCADE)
date_created = models.DateTimeField(default=now, editable=False)
2023-04-22 14:14:53 +08:00
def save(self, *args, **kwargs):
self.name = f"{self.subject} : {self.professor}"
super().save(*args, **kwargs)
2023-04-22 11:59:16 +08:00
def __str__(self):
2023-04-22 14:14:53 +08:00
return self.name
2023-04-22 11:59:16 +08:00
class StudentSchedule(models.Model):
schedule = models.ForeignKey(
'schedules.Schedule', on_delete=models.CASCADE)
student_assigned = models.ForeignKey(
'students.Student', on_delete=models.CASCADE)
date_joined = models.DateTimeField(default=now, editable=False)
2023-04-22 13:42:09 +08:00
def __str__(self):
return self.schedule
2023-04-22 14:07:08 +08:00
'''
class DayTimeSchedule(models.Model):
schedule = models.ForeignKey(
'schedules.Schedule', on_delete=models.CASCADE)
timeschedule = models.ForeignKey(
'daytimes.DayTime', on_delete=models.CASCADE)
def __str__(self):
return self.schedule
'''