2023-11-18 12:57:50 +01:00
|
|
|
from django.core.files.base import ContentFile
|
|
|
|
from django.db import models, IntegrityError
|
2023-11-20 15:56:32 +01:00
|
|
|
from django_softdelete.models import SoftDeleteModel, SoftDeleteManager
|
2023-11-18 12:57:50 +01:00
|
|
|
|
|
|
|
|
2023-11-20 15:56:32 +01:00
|
|
|
class ItemManager(SoftDeleteManager):
|
2023-11-18 12:57:50 +01:00
|
|
|
|
|
|
|
def create(self, **kwargs):
|
|
|
|
if 'uid' in kwargs:
|
|
|
|
raise ValueError('uid must not be set manually')
|
2023-11-20 15:56:32 +01:00
|
|
|
uid = Item.all_objects.filter(event=kwargs['event']).count() + 1
|
2023-11-18 12:57:50 +01:00
|
|
|
kwargs['uid'] = uid
|
|
|
|
return super().create(**kwargs)
|
|
|
|
|
2024-01-07 22:11:13 +01:00
|
|
|
def get_queryset(self):
|
|
|
|
return super().get_queryset().filter(returned_at__isnull=True)
|
|
|
|
|
2023-11-18 12:57:50 +01:00
|
|
|
|
2023-11-20 12:24:27 +01:00
|
|
|
class Item(SoftDeleteModel):
|
2023-11-18 12:57:50 +01:00
|
|
|
iid = models.AutoField(primary_key=True)
|
|
|
|
uid = models.IntegerField()
|
|
|
|
description = models.TextField()
|
|
|
|
event = models.ForeignKey('Event', models.CASCADE, db_column='eid')
|
|
|
|
container = models.ForeignKey('Container', models.CASCADE, db_column='cid')
|
|
|
|
returned_at = models.DateTimeField(blank=True, null=True)
|
2024-01-22 17:21:22 +01:00
|
|
|
created_at = models.DateTimeField(null=True, auto_now_add=True)
|
2023-11-18 12:57:50 +01:00
|
|
|
updated_at = models.DateTimeField(blank=True, null=True)
|
|
|
|
|
|
|
|
objects = ItemManager()
|
2023-11-20 15:56:32 +01:00
|
|
|
all_objects = models.Manager()
|
2023-11-18 12:57:50 +01:00
|
|
|
|
|
|
|
class Meta:
|
|
|
|
unique_together = (('uid', 'event'),)
|
2024-01-07 19:53:25 +01:00
|
|
|
permissions = [
|
|
|
|
('match_item', 'Can match item')
|
|
|
|
]
|
2023-11-18 12:57:50 +01:00
|
|
|
|
2024-06-23 01:20:13 +02:00
|
|
|
def __str__(self):
|
|
|
|
return '[' + str(self.uid) + ']' + self.description
|
|
|
|
|
2024-01-22 17:21:22 +01:00
|
|
|
|
2023-11-20 12:24:27 +01:00
|
|
|
class Container(SoftDeleteModel):
|
2023-11-18 12:57:50 +01:00
|
|
|
cid = models.AutoField(primary_key=True)
|
|
|
|
name = models.CharField(max_length=255)
|
|
|
|
created_at = models.DateTimeField(blank=True, null=True)
|
|
|
|
updated_at = models.DateTimeField(blank=True, null=True)
|
|
|
|
|
2024-06-23 01:20:13 +02:00
|
|
|
def __str__(self):
|
|
|
|
return '[' + str(self.cid) + ']' + self.name
|
|
|
|
|
2023-11-18 12:57:50 +01:00
|
|
|
|
|
|
|
class Event(models.Model):
|
|
|
|
eid = models.AutoField(primary_key=True)
|
|
|
|
name = models.CharField(max_length=255)
|
|
|
|
slug = models.CharField(max_length=255, unique=True)
|
|
|
|
start = models.DateTimeField(blank=True, null=True)
|
|
|
|
end = models.DateTimeField(blank=True, null=True)
|
|
|
|
pre_start = models.DateTimeField(blank=True, null=True)
|
|
|
|
post_end = models.DateTimeField(blank=True, null=True)
|
2024-01-22 17:21:22 +01:00
|
|
|
created_at = models.DateTimeField(null=True, auto_now_add=True)
|
2023-11-18 12:57:50 +01:00
|
|
|
updated_at = models.DateTimeField(blank=True, null=True)
|
2024-06-23 01:20:13 +02:00
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return '[' + str(self.slug) + ']' + self.name
|