Improved schedule models and behavior
This allows for full slot creation now.
This commit is contained in:
parent
143dbbce28
commit
77dc781e0d
2 changed files with 59 additions and 33 deletions
|
@ -1,6 +1,7 @@
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
|
||||||
from symposion.conference.models import Section
|
from symposion.conference.models import Section
|
||||||
|
from symposion.schedule.utils import InlineSet
|
||||||
|
|
||||||
|
|
||||||
class Schedule(models.Model):
|
class Schedule(models.Model):
|
||||||
|
@ -10,50 +11,41 @@ class Schedule(models.Model):
|
||||||
|
|
||||||
class Day(models.Model):
|
class Day(models.Model):
|
||||||
|
|
||||||
|
schedule = models.ForeignKey(Schedule)
|
||||||
date = models.DateField()
|
date = models.DateField()
|
||||||
|
|
||||||
|
class Meta:
|
||||||
|
unique_together = [("schedule", "date")]
|
||||||
|
|
||||||
class Track(models.Model):
|
|
||||||
|
|
||||||
|
class Room(models.Model):
|
||||||
|
|
||||||
|
schedule = models.ForeignKey(Schedule)
|
||||||
name = models.CharField(max_length=65)
|
name = models.CharField(max_length=65)
|
||||||
room = models.CharField(max_length=100)
|
order = models.PositiveIntegerField()
|
||||||
|
|
||||||
|
|
||||||
|
class SlotKind(models.Model):
|
||||||
|
"""
|
||||||
|
A slot kind represents what kind a slot is. For example, a slot can be a
|
||||||
|
break, lunch, or X-minute talk.
|
||||||
|
"""
|
||||||
|
|
||||||
|
schedule = models.ForeignKey(Schedule)
|
||||||
|
label = models.CharField(max_length=50)
|
||||||
|
|
||||||
|
|
||||||
class Slot(models.Model):
|
class Slot(models.Model):
|
||||||
|
|
||||||
day = models.ForeignKey(Day)
|
day = models.ForeignKey(Day)
|
||||||
track_set = models.TextField(db_column="tracks")
|
room_set = models.TextField(db_column="rooms")
|
||||||
|
kind = models.ForeignKey(SlotKind)
|
||||||
start = models.TimeField()
|
start = models.TimeField()
|
||||||
end = models.TimeField()
|
end = models.TimeField()
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def tracks(self):
|
def rooms(self):
|
||||||
attr = "_tracks"
|
attr = "_rooms"
|
||||||
if not hasattr(self, attr):
|
if not hasattr(self, attr):
|
||||||
slot = self
|
setattr(self, attr, InlineSet(obj=self, field="room_set", delimiter=" "))
|
||||||
class TrackSet(object):
|
|
||||||
|
|
||||||
def __init__(self, data, delimiter):
|
|
||||||
self.data = set(data.split(delimiter))
|
|
||||||
|
|
||||||
def __iter__(self):
|
|
||||||
return Track.objects.filter(pk__in=self.data)
|
|
||||||
|
|
||||||
def add(self, track, commit=True):
|
|
||||||
"""
|
|
||||||
Add given track to the set, but check if it can exist
|
|
||||||
before adding it.
|
|
||||||
"""
|
|
||||||
self.data.add(track.pk)
|
|
||||||
self._update_model(commit=commit)
|
|
||||||
|
|
||||||
def remove(self, track, commit=True):
|
|
||||||
self.data.remove(track.pk)
|
|
||||||
self._update_model(commit=commit)
|
|
||||||
|
|
||||||
def _update_model(self, commit=True):
|
|
||||||
slot.track_set += self.delimiter.join(self.data)
|
|
||||||
if commit:
|
|
||||||
slot.save(force_update=True)
|
|
||||||
setattr(self, attr, TrackSet(self.track_set, delimiter=" "))
|
|
||||||
return getattr(self, attr)
|
return getattr(self, attr)
|
||||||
|
|
34
symposion/schedule/utils.py
Normal file
34
symposion/schedule/utils.py
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
class InlineSet(object):
|
||||||
|
|
||||||
|
def __init__(self, obj, field, delimiter):
|
||||||
|
self.obj = obj
|
||||||
|
self.field = field
|
||||||
|
self.data = set([x for x in getattr(obj, field).split(delimiter) if x])
|
||||||
|
self.delimiter = delimiter
|
||||||
|
|
||||||
|
def __iter__(self):
|
||||||
|
return iter(self.queryset())
|
||||||
|
|
||||||
|
def __len__(self):
|
||||||
|
return self.queryset().count()
|
||||||
|
|
||||||
|
def queryset(self):
|
||||||
|
return self.obj.__class__._default_manager.filter(pk__in=self.data)
|
||||||
|
|
||||||
|
def add(self, obj, commit=True):
|
||||||
|
"""
|
||||||
|
Add given room to the set, but check if it can exist
|
||||||
|
before adding it.
|
||||||
|
"""
|
||||||
|
self.data.add(obj.pk)
|
||||||
|
self._update_model(commit=commit)
|
||||||
|
|
||||||
|
def remove(self, obj, commit=True):
|
||||||
|
self.data.remove(obj.pk)
|
||||||
|
self._update_model(commit=commit)
|
||||||
|
|
||||||
|
def _update_model(self, commit=True):
|
||||||
|
value = self.delimiter.join([str(x) for x in self.data])
|
||||||
|
setattr(self.obj, self.field, value)
|
||||||
|
if commit:
|
||||||
|
self.obj.save(force_update=True)
|
Loading…
Reference in a new issue