continue migration: make website working

This commit is contained in:
bkfox
2019-08-05 23:45:20 +02:00
parent 432467ec8d
commit 324cf2ef0f
54 changed files with 8658 additions and 115 deletions

View File

@ -1,4 +1,4 @@
from .page import Page
from .page import Page, NavItem
from .program import Program, Stream, Schedule
from .episode import Episode, Diffusion
from .log import Log

View File

@ -25,6 +25,7 @@ class Episode(Page):
)
objects = InProgramQuerySet.as_manager()
detail_url_name = 'episode-detail'
class Meta:
verbose_name = _('Episode')
@ -36,12 +37,18 @@ class Episode(Page):
super().save(*args, **kwargs)
@classmethod
def from_date(cls, program, date):
title = settings.AIRCOX_EPISODE_TITLE.format(
def get_default_title(cls, program, date):
""" Get default Episode's title """
return settings.AIRCOX_EPISODE_TITLE.format(
program=program,
date=date.strftime(settings.AIRCOX_EPISODE_TITLE_DATE_FORMAT),
)
return cls(program=program, title=title)
@classmethod
def from_date(cls, program, date):
title = cls.get_default_title(program, date)
return cls(program=program, title=title, cover=program.cover)
class DiffusionQuerySet(BaseRerunQuerySet):
def episode(self, episode=None, id=None):

View File

@ -3,14 +3,20 @@ from enum import IntEnum
from django.db import models
from django.urls import reverse
from django.utils.text import slugify
from django.utils.html import format_html
from django.utils.translation import ugettext_lazy as _
from django.contrib.contenttypes.fields import GenericForeignKey
from django.contrib.contenttypes.models import ContentType
from ckeditor.fields import RichTextField
from filer.fields.image import FilerImageField
from model_utils.managers import InheritanceQuerySet
from .station import Station
__all__ = ['Page', 'PageQuerySet']
__all__ = ['PageQuerySet', 'Page', 'NavItem']
class PageQuerySet(InheritanceQuerySet):
@ -48,8 +54,10 @@ class Page(models.Model):
objects = PageQuerySet.as_manager()
detail_url_name = None
class Meta:
abstract=True
abstract = True
def __str__(self):
return '{}: {}'.format(self._meta.verbose_name,
@ -64,10 +72,53 @@ class Page(models.Model):
def get_absolute_url(self):
return reverse(self.detail_url_name, kwargs={'slug': self.slug}) \
if self.is_published else ''
if self.is_published else '#'
@property
def is_draft(self):
return self.status == self.STATUS.draft
@property
def is_published(self):
return self.status == self.STATUS.published
@property
def is_trash(self):
return self.status == self.STATUS.trash
class NavItem(models.Model):
""" Navigation menu items """
station = models.ForeignKey(
Station, models.CASCADE, verbose_name=_('station'))
menu = models.SlugField(_('menu'), max_length=24)
order = models.PositiveSmallIntegerField(_('order'))
text = models.CharField(_('title'), max_length=64)
url = models.CharField(_('url'), max_length=256, blank=True, null=True)
#target_type = models.ForeignKey(
# ContentType, models.CASCADE, blank=True, null=True)
#target_id = models.PositiveSmallIntegerField(blank=True, null=True)
#target = GenericForeignKey('target_type', 'target_id')
class Meta:
verbose_name = _('Menu item')
ordering = ('order', 'pk')
is_active = False
def get_is_active(self, url):
""" Return True if navigation item is active for this url. """
return self.url and url.startswith(self.url)
def render(self, request, css_class='', active_class=''):
if active_class and request.path.startswith(self.url):
css_class += ' ' + active_class
if not self.url:
return self.text
elif not css_class:
return format_html('<a href="{}">{}</a>', self.url, self.text)
else:
return format_html('<a href="{}" class="{}">{}</a>', self.url,
css_class, self.text)

View File

@ -62,6 +62,7 @@ class Program(Page):
)
objects = ProgramQuerySet.as_manager()
detail_url_name = 'program-detail'
@property
def path(self):

View File

@ -5,7 +5,9 @@ from django.db import models
from django.db.models import Q
from django.utils.translation import ugettext_lazy as _
import aircox.settings as settings
from filer.fields.image import FilerImageField
from .. import settings
__all__ = ['Station', 'StationQuerySet', 'Port']
@ -45,6 +47,14 @@ class Station(models.Model):
default=True,
help_text=_('if checked, this station is used as the main one')
)
logo = FilerImageField(
on_delete=models.SET_NULL, null=True, blank=True,
verbose_name=_('Logo'),
)
hosts = models.TextField(
_("website's urls"), max_length=512, null=True, blank=True,
help_text=_('specify one url per line')
)
objects = StationQuerySet.as_manager()
@ -58,15 +68,14 @@ class Station(models.Model):
if self.default:
qs = Station.objects.filter(default=True)
if self.pk:
if self.pk is not None:
qs = qs.exclude(pk=self.pk)
qs.update(default=False)
super().save(*args, **kwargs)
class Port (models.Model):
class Port(models.Model):
"""
Represent an audio input/output for the audio stream
generation.
@ -147,4 +156,3 @@ class Port (models.Model):
)