forked from rc/aircox
continue migration: make website working
This commit is contained in:
@ -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
|
||||
|
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
@ -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):
|
||||
|
@ -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)
|
||||
|
||||
|
@ -62,6 +62,7 @@ class Program(Page):
|
||||
)
|
||||
|
||||
objects = ProgramQuerySet.as_manager()
|
||||
detail_url_name = 'program-detail'
|
||||
|
||||
@property
|
||||
def path(self):
|
||||
|
@ -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):
|
||||
)
|
||||
|
||||
|
||||
|
||||
|
Reference in New Issue
Block a user