56 lines
1.7 KiB
Python
Raw Normal View History

from datetime import timedelta
2025-01-25 00:47:31 +01:00
from django.db import models
class Parent(models.Model):
2025-02-02 18:47:35 +01:00
project_num = models.CharField(max_length=32, blank=True, verbose_name="Project number")
2025-01-25 00:47:31 +01:00
name = models.CharField(max_length=256)
2025-02-02 18:47:35 +01:00
is_productive = models.BooleanField(default=False)
2025-01-25 00:47:31 +01:00
2025-01-26 00:53:17 +01:00
def __str__(self):
return self.name
2025-01-25 00:47:31 +01:00
class Project(models.Model):
2025-01-26 00:53:17 +01:00
parent = models.ForeignKey(
Parent,
on_delete=models.CASCADE,
null=True
)
2025-01-25 00:47:31 +01:00
name = models.CharField(max_length=256)
2025-01-26 00:53:17 +01:00
def __str__(self):
return self.name
2025-01-25 00:47:31 +01:00
class Task(models.Model):
project = models.ForeignKey(Project, on_delete=models.CASCADE)
date = models.DateField(null=False)
duration = models.IntegerField(null=False, default=0)
2025-01-26 00:53:17 +01:00
name = models.CharField(max_length=512, default="")
class Meta:
constraints = [
models.UniqueConstraint(fields=["date", "project", "name"], name="unique_daily_task")
]
class Clocking(models.Model):
date = models.DateField()
2025-02-02 18:47:35 +01:00
in_am = models.TimeField(null=True, default=None, verbose_name="Clock in AM")
out_am = models.TimeField(null=True, default=None, verbose_name="Clock out AM")
in_pm = models.TimeField(null=True, default=None, verbose_name="Clock in PM")
out_pm = models.TimeField(null=True, default=None, verbose_name="Clock out PM")
remote = models.DurationField(default=timedelta)
class RealSageXHours(models.Model):
parent = models.ForeignKey(Parent, on_delete=models.CASCADE)
date = models.DateField()
hours = models.DurationField(default=timedelta)
class Meta:
constraints = [
models.UniqueConstraint(fields=["parent", "date"], name="unique_monthly_sagex")
]