add DiffusionManager, use it
This commit is contained in:
@ -50,13 +50,60 @@ class Program (cms.RelatedPost):
|
||||
auto_create = True
|
||||
|
||||
|
||||
class Diffusion (cms.RelatedPost):
|
||||
class DiffusionManager(models.Manager):
|
||||
@staticmethod
|
||||
def post_or_default(diff, post, create = True, save = False):
|
||||
if not post and create:
|
||||
post = Diffusion(related = diff.initial or diff)
|
||||
if save:
|
||||
post.save()
|
||||
else:
|
||||
post.rel_to_post()
|
||||
if post:
|
||||
post.date = diff.start
|
||||
post.related = diff
|
||||
return post
|
||||
|
||||
def get_for(self, diffs, create = True, save = False):
|
||||
"""
|
||||
Get posts for the given related diffusion. Return a list
|
||||
not a Queryset, ordered following the given list.
|
||||
|
||||
Update the post objects to make date corresponding to the
|
||||
diffusions.
|
||||
|
||||
- diffs: a programs.Diffusion, or iterable of
|
||||
programs.Diffusion. In the first case, return
|
||||
an object instead of a list
|
||||
- create: create a post for each Diffusion if missing
|
||||
- save: save the created posts
|
||||
"""
|
||||
if not hasattr(diffs, '__iter__'):
|
||||
qs = self.filter(related = diffs.initial or diff,
|
||||
published = True)
|
||||
return post_or_default(diffs, post, create, save)
|
||||
|
||||
qs = self.filter(related__in = [
|
||||
diff.initial or diff for diff in diffs
|
||||
], published = True)
|
||||
posts = []
|
||||
for diff in diffs:
|
||||
post = qs.filter(related = diff.initial or diff).first()
|
||||
post = self.post_or_default(diff, post, create, save)
|
||||
if post:
|
||||
posts.append(post)
|
||||
return posts
|
||||
|
||||
|
||||
class Diffusion(cms.RelatedPost):
|
||||
objects = DiffusionManager()
|
||||
actions = [actions.Play, actions.AddToPlaylist]
|
||||
|
||||
class Relation:
|
||||
model = programs.Diffusion
|
||||
bindings = {
|
||||
'thread': 'program',
|
||||
'title': lambda post, rel: rel.program.name,
|
||||
'date': 'start',
|
||||
}
|
||||
fields_args = {
|
||||
@ -69,9 +116,16 @@ class Diffusion (cms.RelatedPost):
|
||||
def auto_create(object):
|
||||
return not object.initial
|
||||
|
||||
def __init__(self, *args, **kwargs):
|
||||
def __init__(self, *args, rel_to_post = False, **kwargs):
|
||||
super().__init__(*args, **kwargs)
|
||||
if rel_to_post and self.related:
|
||||
self.rel_to_post()
|
||||
|
||||
self.fill_empty()
|
||||
if not self.subtitle:
|
||||
self.subtitle = _('Diffusion of the %(date)s') % {
|
||||
'date': self.related.start.strftime('%A %d/%m')
|
||||
}
|
||||
|
||||
@property
|
||||
def info(self):
|
||||
@ -81,3 +135,14 @@ class Diffusion (cms.RelatedPost):
|
||||
'day': self.related.initial.start.strftime('%A %d/%m')
|
||||
}
|
||||
|
||||
def url(self):
|
||||
url = super().url()
|
||||
if url or not self.related.initial:
|
||||
return url
|
||||
|
||||
post = Diffusions.objects.filter(related = self.related.initial) \
|
||||
.first()
|
||||
return post.url() if post else ''
|
||||
|
||||
|
||||
|
||||
|
@ -141,52 +141,9 @@ class Diffusions(sections.List):
|
||||
# .order_by('-start')[:self.prev_count])
|
||||
#return r
|
||||
|
||||
def prepare_list(self, object_list):
|
||||
"""
|
||||
This function just prepare the list of object, in order to:
|
||||
- have a good title
|
||||
- given a stream to listen to if needed
|
||||
"""
|
||||
for post in object_list:
|
||||
# title
|
||||
if not hasattr(post, 'related') or \
|
||||
not hasattr(post.related , 'program'):
|
||||
continue
|
||||
name = post.related.program.name
|
||||
if name not in post.title:
|
||||
post.title = ': ' + post.title if post.title else \
|
||||
' // ' + post.related.start.strftime('%A %d %B')
|
||||
post.title = name + post.title
|
||||
return object_list
|
||||
|
||||
def get_object_list(self):
|
||||
diffs = self.get_diffs()
|
||||
|
||||
posts = models.Diffusion.objects.filter(related__in = diffs)
|
||||
r = []
|
||||
for diff in diffs:
|
||||
diff_ = diff.initial if diff.initial else diff
|
||||
post = next((x for x in posts if x.related == diff_), None)
|
||||
if not post:
|
||||
post = sections.ListItem(date = diff.start)
|
||||
else:
|
||||
post = sections.ListItem(post=post)
|
||||
post.date = diff.start
|
||||
|
||||
if diff.initial:
|
||||
post.info = _('rerun of %(day)s') % {
|
||||
'day': diff.initial.start.strftime('%A %d/%m')
|
||||
}
|
||||
|
||||
if self.object:
|
||||
post.update(self.object)
|
||||
else:
|
||||
thread = models.Program.objects. \
|
||||
filter(related = diff.program, published = True)
|
||||
if thread:
|
||||
post.update(thread[0])
|
||||
r.append(post)
|
||||
return [ sections.ListItem(post=post) for post in r ]
|
||||
diffs = self.get_diffs().order_by('start')
|
||||
return models.Diffusion.objects.get_for(diffs)
|
||||
|
||||
@property
|
||||
def url(self):
|
||||
@ -255,7 +212,6 @@ class Sounds(sections.List):
|
||||
]
|
||||
|
||||
|
||||
|
||||
class ListByDate(sections.List):
|
||||
"""
|
||||
List that add a navigation by date in its header.
|
||||
@ -354,10 +310,11 @@ class Schedule(Diffusions,ListByDate):
|
||||
|
||||
def get_object_list(self):
|
||||
date = self.date_or_default()
|
||||
return routes.DateRoute.get_queryset(
|
||||
models.Diffusion, self.request, date.year, date.month,
|
||||
date.day
|
||||
).order_by('date')
|
||||
diffs = routes.DateRoute.get_queryset(
|
||||
programs.Diffusion, None, date.year, date.month, date.day,
|
||||
attr = 'start'
|
||||
).order_by('start')
|
||||
return models.Diffusion.objects.get_for(diffs, create = True)
|
||||
|
||||
@staticmethod
|
||||
def get_date_url(date):
|
||||
@ -400,6 +357,10 @@ class Logs(ListByDate):
|
||||
)
|
||||
return post
|
||||
|
||||
@staticmethod
|
||||
def make_diff(diff):
|
||||
pass
|
||||
|
||||
def get_object_list(self):
|
||||
return []
|
||||
station = self.view.website.station
|
||||
@ -409,8 +370,11 @@ class Logs(ListByDate):
|
||||
date__year = int(year), date__month = int(month),
|
||||
date__day = int(day)
|
||||
)
|
||||
# TODO for each, exclude if there is a diffusion (that has not been logged)
|
||||
return [ cl.make_item(log) for log in qs ]
|
||||
# TODO for each, exclude if there is a corresponding diffusion
|
||||
# (that has not been logged)
|
||||
# if diff and diff != last_diff:
|
||||
# r.append(cl.make_item
|
||||
# return [ cl.make_item(log) for log in qs ]
|
||||
|
||||
@staticmethod
|
||||
def get_date_url(date):
|
||||
|
Reference in New Issue
Block a user