2010-04-15 12:41:08 +00:00
|
|
|
import datetime
|
2011-10-13 21:34:56 +00:00
|
|
|
|
2015-01-28 07:35:27 -05:00
|
|
|
from django.db import DJANGO_VERSION_PICKLE_KEY, models
|
2017-01-26 20:58:33 +01:00
|
|
|
from django.utils.translation import gettext_lazy as _
|
2010-03-27 15:54:31 +00:00
|
|
|
|
2011-10-13 21:34:56 +00:00
|
|
|
|
2013-03-29 13:32:21 +01:00
|
|
|
def standalone_number():
|
2010-04-21 16:34:33 +00:00
|
|
|
return 1
|
|
|
|
|
2013-11-02 16:34:05 -05:00
|
|
|
|
2017-01-19 02:39:46 -05:00
|
|
|
class Numbers:
|
2010-04-21 16:34:33 +00:00
|
|
|
@staticmethod
|
2013-03-29 13:32:21 +01:00
|
|
|
def get_static_number():
|
2010-04-21 16:34:33 +00:00
|
|
|
return 2
|
2010-04-15 12:41:08 +00:00
|
|
|
|
2013-11-02 16:34:05 -05:00
|
|
|
|
2014-06-06 16:40:20 +05:30
|
|
|
class PreviousDjangoVersionQuerySet(models.QuerySet):
|
|
|
|
def __getstate__(self):
|
2017-01-21 18:43:44 +05:30
|
|
|
state = super().__getstate__()
|
2015-04-01 19:15:27 -04:00
|
|
|
state[DJANGO_VERSION_PICKLE_KEY] = '1.0'
|
2014-06-06 16:40:20 +05:30
|
|
|
return state
|
|
|
|
|
|
|
|
|
|
|
|
class MissingDjangoVersionQuerySet(models.QuerySet):
|
|
|
|
def __getstate__(self):
|
2017-01-21 18:43:44 +05:30
|
|
|
state = super().__getstate__()
|
2014-06-06 16:40:20 +05:30
|
|
|
del state[DJANGO_VERSION_PICKLE_KEY]
|
|
|
|
return state
|
|
|
|
|
|
|
|
|
2010-03-27 15:54:31 +00:00
|
|
|
class Group(models.Model):
|
|
|
|
name = models.CharField(_('name'), max_length=100)
|
2014-06-06 16:40:20 +05:30
|
|
|
objects = models.Manager()
|
|
|
|
previous_django_version_objects = PreviousDjangoVersionQuerySet.as_manager()
|
|
|
|
missing_django_version_objects = MissingDjangoVersionQuerySet.as_manager()
|
2010-03-27 15:54:31 +00:00
|
|
|
|
2013-11-02 16:34:05 -05:00
|
|
|
|
2010-03-27 15:54:31 +00:00
|
|
|
class Event(models.Model):
|
2014-12-24 14:58:32 +01:00
|
|
|
title = models.CharField(max_length=100)
|
2020-10-05 09:21:16 -04:00
|
|
|
group = models.ForeignKey(Group, models.CASCADE, limit_choices_to=models.Q())
|
2010-04-15 12:41:08 +00:00
|
|
|
|
2013-11-02 16:34:05 -05:00
|
|
|
|
2010-04-15 12:41:08 +00:00
|
|
|
class Happening(models.Model):
|
|
|
|
when = models.DateTimeField(blank=True, default=datetime.datetime.now)
|
2015-07-15 21:18:07 -04:00
|
|
|
name = models.CharField(blank=True, max_length=100, default="test")
|
2010-04-21 16:34:33 +00:00
|
|
|
number1 = models.IntegerField(blank=True, default=standalone_number)
|
2016-12-01 11:38:01 +01:00
|
|
|
number2 = models.IntegerField(blank=True, default=Numbers.get_static_number)
|
2017-10-18 21:43:53 -04:00
|
|
|
event = models.OneToOneField(Event, models.CASCADE, null=True)
|
2013-05-21 12:57:24 +03:00
|
|
|
|
2013-11-02 16:34:05 -05:00
|
|
|
|
2017-01-19 02:39:46 -05:00
|
|
|
class Container:
|
2013-05-21 12:57:24 +03:00
|
|
|
# To test pickling we need a class that isn't defined on module, but
|
|
|
|
# is still available from app-cache. So, the Container class moves
|
|
|
|
# SomeModel outside of module level
|
|
|
|
class SomeModel(models.Model):
|
|
|
|
somefield = models.IntegerField()
|
|
|
|
|
2013-11-02 16:34:05 -05:00
|
|
|
|
2013-05-21 12:57:24 +03:00
|
|
|
class M2MModel(models.Model):
|
2020-10-15 08:17:42 +02:00
|
|
|
added = models.DateField(default=datetime.date.today)
|
2013-05-21 12:57:24 +03:00
|
|
|
groups = models.ManyToManyField(Group)
|
2019-12-11 15:25:50 +01:00
|
|
|
|
|
|
|
|
|
|
|
class AbstractEvent(Event):
|
|
|
|
class Meta:
|
|
|
|
abstract = True
|
|
|
|
ordering = ['title']
|
|
|
|
|
|
|
|
|
|
|
|
class MyEvent(AbstractEvent):
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
|
|
class Edition(models.Model):
|
|
|
|
event = models.ForeignKey('MyEvent', on_delete=models.CASCADE)
|