42 lines
1.4 KiB
Python
42 lines
1.4 KiB
Python
from django.db import models
|
|
from django.core.validators import MinValueValidator
|
|
from decimal import Decimal
|
|
|
|
class Project(models.Model):
|
|
name = models.CharField(max_length=200)
|
|
description = models.TextField(blank=True)
|
|
created_at = models.DateTimeField(auto_now_add=True)
|
|
|
|
def __str__(self):
|
|
return self.name
|
|
|
|
class Worker(models.Model):
|
|
name = models.CharField(max_length=200)
|
|
id_no = models.CharField(max_length=50, unique=True, verbose_name="ID Number")
|
|
phone_no = models.CharField(max_length=20, verbose_name="Phone Number")
|
|
monthly_salary = models.DecimalField(max_digits=10, decimal_places=2, validators=[MinValueValidator(Decimal('0.00'))])
|
|
created_at = models.DateTimeField(auto_now_add=True)
|
|
|
|
@property
|
|
def day_rate(self):
|
|
return self.monthly_salary / Decimal('20.0')
|
|
|
|
def __str__(self):
|
|
return self.name
|
|
|
|
class Team(models.Model):
|
|
name = models.CharField(max_length=200)
|
|
workers = models.ManyToManyField(Worker, related_name='teams')
|
|
created_at = models.DateTimeField(auto_now_add=True)
|
|
|
|
def __str__(self):
|
|
return self.name
|
|
|
|
class WorkLog(models.Model):
|
|
date = models.DateField()
|
|
project = models.ForeignKey(Project, on_delete=models.CASCADE, related_name='logs')
|
|
workers = models.ManyToManyField(Worker, related_name='work_logs')
|
|
notes = models.TextField(blank=True)
|
|
|
|
def __str__(self):
|
|
return f"{self.date} - {self.project.name}" |