forked from rc/aircox
work on schedule; section.as_view()
This commit is contained in:
@ -14,8 +14,6 @@ class Diffusions(sections.List):
|
||||
Section that print diffusions. When rendering, if there is no post yet
|
||||
associated, use the programs' article.
|
||||
"""
|
||||
next_count = 5
|
||||
prev_count = 5
|
||||
order_by = '-start'
|
||||
show_schedule = False
|
||||
|
||||
@ -32,16 +30,16 @@ class Diffusions(sections.List):
|
||||
if filter_args:
|
||||
qs = qs.filter(**filter_args).order_by('start')
|
||||
|
||||
r = []
|
||||
if not self.next_count and not self.prev_count:
|
||||
return qs
|
||||
if self.next_count:
|
||||
r += list(programs.Diffusion.get(next=True, queryset = qs)
|
||||
.order_by('-start')[:self.next_count])
|
||||
if self.prev_count:
|
||||
r += list(programs.Diffusion.get(prev=True, queryset = qs)
|
||||
.order_by('-start')[:self.prev_count])
|
||||
return r
|
||||
return qs
|
||||
|
||||
#r = []
|
||||
#if self.next_count:
|
||||
# r += list(programs.Diffusion.get(next=True, queryset = qs)
|
||||
# .order_by('-start')[:self.next_count])
|
||||
#if self.prev_count:
|
||||
# r += list(programs.Diffusion.get(prev=True, queryset = qs)
|
||||
# .order_by('-start')[:self.prev_count])
|
||||
#return r
|
||||
|
||||
def get_object_list(self):
|
||||
diffs = self.get_diffs()
|
||||
@ -59,7 +57,7 @@ class Diffusions(sections.List):
|
||||
|
||||
if diff.initial:
|
||||
post.info = _('rerun of %(day)s') % {
|
||||
'day': diff.initial.date.strftime('%A %d/%m')
|
||||
'day': diff.initial.start.strftime('%A %d/%m')
|
||||
}
|
||||
|
||||
if self.object:
|
||||
@ -121,10 +119,7 @@ class Schedule(Diffusions):
|
||||
Render a list of diffusions in the form of a schedule
|
||||
"""
|
||||
template_name = 'aircox/website/schedule.html'
|
||||
next_count = None
|
||||
prev_count = None
|
||||
date = None
|
||||
days = 7
|
||||
nav_date_format = '%a. %d'
|
||||
fields = [ 'time', 'image', 'title']
|
||||
|
||||
@ -134,13 +129,16 @@ class Schedule(Diffusions):
|
||||
|
||||
@staticmethod
|
||||
def get_week_dates(date):
|
||||
"""
|
||||
Return a list of dates of the week of the given date.
|
||||
"""
|
||||
first = date - tz.timedelta(days=date.weekday())
|
||||
return [ first + tz.timedelta(days=i) for i in range(0, 7) ]
|
||||
|
||||
def date_or_default(self):
|
||||
if self.date:
|
||||
return self.date
|
||||
elif 'year' in self.kwargs:
|
||||
elif self.kwargs and 'year' in self.kwargs:
|
||||
return tz.datetime(year = int(self.kwargs['year']),
|
||||
month = int(self.kwargs['month']),
|
||||
day = int(self.kwargs['day']),
|
||||
@ -148,18 +146,21 @@ class Schedule(Diffusions):
|
||||
microsecond = 0)
|
||||
return tz.datetime.now()
|
||||
|
||||
def get_diffs(self):
|
||||
def get_object_list(self):
|
||||
date = self.date_or_default()
|
||||
diffs = super().get_diffs(
|
||||
start__year = date.year,
|
||||
start__month = date.month,
|
||||
start__day = date.day,
|
||||
)
|
||||
return diffs
|
||||
qs = routes.DateRoute.get_queryset(
|
||||
models.Diffusion, self.request,
|
||||
year = date.year,
|
||||
month = date.month,
|
||||
day = date.day
|
||||
).order_by('date')
|
||||
return qs
|
||||
|
||||
def get_context_data(self, *args, **kwargs):
|
||||
context = super().get_context_data(*args, **kwargs)
|
||||
|
||||
def get_context_data(self, **kwargs):
|
||||
date = self.date_or_default()
|
||||
dates_url = [
|
||||
dates = [
|
||||
(date, models.Diffusion.route_url(
|
||||
routes.DateRoute,
|
||||
year = date.year, month = date.month, day = date.day
|
||||
@ -167,13 +168,33 @@ class Schedule(Diffusions):
|
||||
for date in self.get_week_dates(date)
|
||||
]
|
||||
|
||||
context = super().get_context_data(**kwargs)
|
||||
next_week = dates[-1][0] + tz.timedelta(days=1)
|
||||
next_week = models.Diffusion.route_url(
|
||||
routes.DateRoute,
|
||||
year = next_week.year, month = next_week.month,
|
||||
day = next_week.day
|
||||
)
|
||||
|
||||
prev_week = dates[0][0] - tz.timedelta(days=1)
|
||||
prev_week = models.Diffusion.route_url(
|
||||
routes.DateRoute,
|
||||
year = prev_week.year, month = prev_week.month,
|
||||
day = prev_week.day
|
||||
)
|
||||
|
||||
context.update({
|
||||
'date': date,
|
||||
'dates_url': dates_url,
|
||||
'dates': dates,
|
||||
'next_week': next_week,
|
||||
'prev_week': prev_week,
|
||||
})
|
||||
return context
|
||||
|
||||
@property
|
||||
def url(self):
|
||||
return None
|
||||
|
||||
|
||||
|
||||
#class DatesOfDiffusion(sections.List):
|
||||
# title = _('Dates of diffusion')
|
||||
|
Reference in New Issue
Block a user