models.py 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. from django.db import models
  2. from django.utils.translation import gettext_lazy as _
  3. # Create your models here.
  4. class Employee(models.Model):
  5. name = models.CharField(max_length=100)
  6. daily_workhours = models.PositiveIntegerField()
  7. info = models.TextField(blank=True, null=True)
  8. def __str__(self):
  9. return self.name
  10. class Shift(models.Model):
  11. class ShiftType(models.TextChoices):
  12. NONE = 'N', _('None') # Placeholder for "None" if you're using it
  13. VACATION = 'U', _('Urlaub')
  14. CATERING = 'C', _('Catering')
  15. SICK = 'K', _('Krank')
  16. RB = 'RB', _('Rufbereitschaft')
  17. SD = 'SO', _('Sonderdienst')
  18. KK = 'KKH', _('KKH')
  19. ST = 'ST', _('Stapler')
  20. AH = 'AH', _('Ausser Haus')
  21. date = models.DateField()
  22. start = models.TimeField(null=True, blank=True)
  23. end = models.TimeField(null=True, blank=True)
  24. shifttype = models.CharField(
  25. max_length=3,
  26. choices=ShiftType.choices,
  27. default=ShiftType.NONE,
  28. null=True,
  29. )
  30. employee = models.ForeignKey(Employee, on_delete=models.CASCADE)
  31. def __str__(self):
  32. return f"{self.date} - {self.get_shifttype_display()}"
  33. class Location(models.Model):
  34. name = models.CharField(max_length=100)
  35. def __str__(self):
  36. return self.name
  37. class Event(models.Model):
  38. class EventType(models.TextChoices):
  39. NONE = '', _('None')
  40. AUFBAU = 'AU', _('Aufbau')
  41. ABBAU = 'AB', _('Abbau')
  42. UMBAU = 'UM', _('Umbau')
  43. VATAG = 'VA', _('VA-Tag')
  44. SPIELTAG = 'ST', _('Spieltag')
  45. TRAINING = 'TR', _('Training')
  46. date = models.DateField()
  47. name = models.CharField(max_length=100)
  48. event_type = models.CharField(
  49. max_length=2,
  50. choices=EventType.choices,
  51. default=EventType.NONE,
  52. null=True,
  53. )
  54. location = models.ForeignKey(Location, on_delete=models.CASCADE)
  55. cvd = models.ForeignKey(Employee, related_name='cvt', on_delete=models.SET_NULL, null=True, blank=True)
  56. cvt = models.ForeignKey(Employee, related_name='cvd', on_delete=models.SET_NULL, null=True, blank=True)
  57. def __str__(self):
  58. return f"{self.date} - {self.name}"