1
0
clubhaus-schornbach/clubhaus/homepage/models.py

69 lines
2.1 KiB
Python

from django.db import models
# Create your models here.
from django.utils import timezone
class TobaccoCategory(models.Model):
name = models.CharField(max_length=200, unique=True, blank=False, null=False)
def __str__(self):
return f"{self.name} ({self.id})"
class Tobacco(models.Model):
name = models.CharField(max_length=200, unique=True, blank=False, null=False)
description = models.TextField(blank=True, null=False)
category = models.ForeignKey("TobaccoCategory", on_delete=models.CASCADE, blank=False, null=False)
in_stock = models.BooleanField()
picture = models.ImageField(upload_to="tobacco_images/", null=False, blank=True)
def __str__(self):
return self.name
class EventDate(models.Model):
event = models.ForeignKey(to="ClubhausEvent", on_delete=models.CASCADE)
date = models.DateTimeField(unique=True, default=timezone.now)
def __str__(self):
return f"{self.event.name} - {self.date.date().isoformat()}"
class ClubhausEvent(models.Model):
name = models.CharField(max_length=200, blank=True)
date = models.DateTimeField(blank=True, null=True)
active = models.BooleanField(default=False)
location = models.TextField(blank=True)
beverages = models.TextField(blank=True)
food = models.TextField(blank=True)
def __str__(self):
return f"{self.name}"
class EventDateVotes(models.Model):
voter = models.ForeignKey(to="VotingUser", on_delete=models.CASCADE)
date = models.ForeignKey(to="EventDate", to_field="date", on_delete=models.CASCADE)
class Meta:
constraints = [
models.UniqueConstraint(fields=("voter", "date"), name="unique_voter_day")
]
def __str__(self):
return f"{self.voter.name}({self.voter.id}) - {self.date.date.isoformat()}"
class VotingUser(models.Model):
name = models.CharField(max_length=200, blank=False)
modify_key = models.CharField(max_length=200, blank=False)
class Meta:
constraints = [
models.UniqueConstraint(fields=("name", "modify_key"), name="unique_name_modify_key")
]
def __str__(self):
return f"{self.name}({self.id})"