2024-11-20 23:58:14 +00:00
|
|
|
from itertools import groupby
|
|
|
|
|
|
|
|
from django.db import models
|
2023-11-20 14:56:32 +00:00
|
|
|
from django_softdelete.models import SoftDeleteModel, SoftDeleteManager
|
2023-11-18 11:57:50 +00:00
|
|
|
|
|
|
|
|
2023-11-20 14:56:32 +00:00
|
|
|
class ItemManager(SoftDeleteManager):
|
2023-11-18 11:57:50 +00:00
|
|
|
|
|
|
|
def create(self, **kwargs):
|
2024-11-23 00:22:24 +00:00
|
|
|
container = kwargs.pop('container')
|
2024-11-19 23:23:20 +00:00
|
|
|
if 'uid_deprecated' in kwargs:
|
|
|
|
raise ValueError('uid_deprecated must not be set manually')
|
|
|
|
uid_deprecated = Item.all_objects.filter(event=kwargs['event']).count() + 1
|
|
|
|
kwargs['uid_deprecated'] = uid_deprecated
|
2024-11-23 00:22:24 +00:00
|
|
|
item = super().create(**kwargs)
|
|
|
|
item.container = container
|
|
|
|
return item
|
2023-11-18 11:57:50 +00:00
|
|
|
|
2024-01-07 21:11:13 +00:00
|
|
|
def get_queryset(self):
|
|
|
|
return super().get_queryset().filter(returned_at__isnull=True)
|
|
|
|
|
2023-11-18 11:57:50 +00:00
|
|
|
|
2023-11-20 11:24:27 +00:00
|
|
|
class Item(SoftDeleteModel):
|
2024-11-19 23:23:20 +00:00
|
|
|
id = models.AutoField(primary_key=True)
|
|
|
|
uid_deprecated = models.IntegerField()
|
2023-11-18 11:57:50 +00:00
|
|
|
description = models.TextField()
|
2024-11-19 23:23:20 +00:00
|
|
|
event = models.ForeignKey('Event', models.CASCADE)
|
2023-11-18 11:57:50 +00:00
|
|
|
returned_at = models.DateTimeField(blank=True, null=True)
|
2024-01-22 16:21:22 +00:00
|
|
|
created_at = models.DateTimeField(null=True, auto_now_add=True)
|
2023-11-18 11:57:50 +00:00
|
|
|
updated_at = models.DateTimeField(blank=True, null=True)
|
|
|
|
|
2024-11-23 00:22:24 +00:00
|
|
|
@property
|
|
|
|
def container(self):
|
|
|
|
try:
|
2024-11-29 00:32:54 +00:00
|
|
|
history = sorted(self.container_history.all(), key=lambda x: x.timestamp, reverse=True)
|
|
|
|
if history:
|
|
|
|
return history[0].container
|
|
|
|
else:
|
|
|
|
return None
|
2024-11-23 00:22:24 +00:00
|
|
|
except AttributeError:
|
|
|
|
return None
|
|
|
|
|
|
|
|
@container.setter
|
|
|
|
def container(self, value):
|
|
|
|
if self.container == value:
|
|
|
|
return
|
|
|
|
self.container_history.create(container=value)
|
|
|
|
|
2024-11-20 23:58:14 +00:00
|
|
|
@property
|
|
|
|
def related_issues(self):
|
|
|
|
groups = groupby(self.issue_relation_changes.all(), lambda rel: rel.issue_thread.id)
|
|
|
|
return [sorted(v, key=lambda r: r.timestamp)[0].issue_thread for k, v in groups]
|
|
|
|
|
2023-11-18 11:57:50 +00:00
|
|
|
objects = ItemManager()
|
2023-11-20 14:56:32 +00:00
|
|
|
all_objects = models.Manager()
|
2023-11-18 11:57:50 +00:00
|
|
|
|
|
|
|
class Meta:
|
2024-11-19 23:23:20 +00:00
|
|
|
unique_together = (('uid_deprecated', 'event'),)
|
2024-01-07 18:53:25 +00:00
|
|
|
permissions = [
|
|
|
|
('match_item', 'Can match item')
|
|
|
|
]
|
2023-11-18 11:57:50 +00:00
|
|
|
|
2024-06-22 23:20:13 +00:00
|
|
|
def __str__(self):
|
2024-11-19 23:23:20 +00:00
|
|
|
return '[' + str(self.id) + ']' + self.description
|
2024-06-22 23:20:13 +00:00
|
|
|
|
2024-01-22 16:21:22 +00:00
|
|
|
|
2023-11-20 11:24:27 +00:00
|
|
|
class Container(SoftDeleteModel):
|
2024-11-19 23:23:20 +00:00
|
|
|
id = models.AutoField(primary_key=True)
|
2023-11-18 11:57:50 +00:00
|
|
|
name = models.CharField(max_length=255)
|
|
|
|
created_at = models.DateTimeField(blank=True, null=True)
|
|
|
|
updated_at = models.DateTimeField(blank=True, null=True)
|
|
|
|
|
2024-11-23 00:22:24 +00:00
|
|
|
@property
|
|
|
|
def items(self):
|
|
|
|
try:
|
|
|
|
history = self.item_history.order_by('-timestamp').all()
|
|
|
|
return [v for k, v in groupby(history, key=lambda item: item.item.id)]
|
|
|
|
except AttributeError:
|
|
|
|
return []
|
|
|
|
|
2024-06-22 23:20:13 +00:00
|
|
|
def __str__(self):
|
2024-11-19 23:23:20 +00:00
|
|
|
return '[' + str(self.id) + ']' + self.name
|
2024-06-22 23:20:13 +00:00
|
|
|
|
2023-11-18 11:57:50 +00:00
|
|
|
|
2024-11-23 00:22:24 +00:00
|
|
|
class ItemPlacement(models.Model):
|
|
|
|
id = models.AutoField(primary_key=True)
|
|
|
|
item = models.ForeignKey('Item', models.CASCADE, related_name='container_history')
|
|
|
|
container = models.ForeignKey('Container', models.CASCADE, related_name='item_history')
|
|
|
|
timestamp = models.DateTimeField(auto_now_add=True)
|
|
|
|
|
|
|
|
|
|
|
|
class Comment(models.Model):
|
|
|
|
id = models.AutoField(primary_key=True)
|
|
|
|
item = models.ForeignKey(Item, on_delete=models.CASCADE, related_name='comments')
|
|
|
|
comment = models.TextField()
|
|
|
|
timestamp = models.DateTimeField(auto_now_add=True)
|
|
|
|
|
|
|
|
def __str__(self):
|
2024-11-23 13:40:13 +00:00
|
|
|
return str(self.item) + ' comment #' + str(self.id)
|
2024-11-23 00:22:24 +00:00
|
|
|
|
|
|
|
|
2023-11-18 11:57:50 +00:00
|
|
|
class Event(models.Model):
|
2024-11-19 23:23:20 +00:00
|
|
|
id = models.AutoField(primary_key=True)
|
2023-11-18 11:57:50 +00:00
|
|
|
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 16:21:22 +00:00
|
|
|
created_at = models.DateTimeField(null=True, auto_now_add=True)
|
2023-11-18 11:57:50 +00:00
|
|
|
updated_at = models.DateTimeField(blank=True, null=True)
|
2024-06-22 23:20:13 +00:00
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return '[' + str(self.slug) + ']' + self.name
|
2024-11-19 23:23:20 +00:00
|
|
|
|
|
|
|
class Meta:
|
2024-11-23 00:22:24 +00:00
|
|
|
db_table = 'common_event'
|