X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/deb806113c76384876cd4969dc20c1e76ddabfef..0ffaeae32918d959e94e2d94e0a020458a409a3a:/src/social/models.py?ds=sidebyside
diff --git a/src/social/models.py b/src/social/models.py
index c6a1815bf..6f1f697fa 100644
--- a/src/social/models.py
+++ b/src/social/models.py
@@ -1,11 +1,12 @@
# This file is part of Wolnelektury, licensed under GNU Affero GPLv3 or later.
# Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information.
#
+from random import randint
from django.db import models
from django.conf import settings
from django.core.exceptions import ValidationError
from django.core.urlresolvers import reverse
-from django.utils.translation import ugettext_lazy as _
+from django.utils.translation import ugettext_lazy as _, string_concat
from ssify import flush_ssi_includes
from catalogue.models import Book
@@ -26,6 +27,13 @@ class BannerGroup(models.Model):
"""This is used for testing."""
return "%s?banner_group=%d" % (reverse('main_page'), self.id)
+ def get_banner(self):
+ banners = self.cite_set.all()
+ count = banners.count()
+ if not count:
+ return None
+ return banners[randint(0, count-1)]
+
class Cite(models.Model):
book = models.ForeignKey(Book, verbose_name=_('book'), null=True, blank=True)
@@ -34,18 +42,27 @@ class Cite(models.Model):
vip = models.CharField(_('VIP'), max_length=128, null=True, blank=True)
link = models.URLField(_('link'))
video = models.URLField(_('video'), blank=True)
- picture = models.ImageField(_('picture'), blank=True)
+ picture = models.ImageField(_('picture'), blank=True,
+ help_text='Najlepsze wymiary: 975 x 315 z tekstem, 487 x 315 bez tekstu.')
+ picture_alt = models.CharField(_('picture alternative text'), max_length=255, blank=True)
+ picture_title = models.CharField(_('picture title'), max_length=255, null=True, blank=True)
+ picture_author = models.CharField(_('picture author'), max_length=255, blank=True, null=True)
+ picture_link = models.URLField(_('picture link'), blank=True, null=True)
+ picture_license = models.CharField(_('picture license name'), max_length=255, blank=True, null=True)
+ picture_license_link = models.URLField(_('picture license link'), blank=True, null=True)
sticky = models.BooleanField(_('sticky'), default=False, db_index=True,
help_text=_('Sticky cites will take precedense.'))
- banner = models.BooleanField(_('banner'), default=False, help_text=_('Adjust size to image, ignore the text'))
+ banner = models.BooleanField(_('banner'), default=False, help_text=string_concat(_('Adjust size to image, ignore the text'), '
(PrzestarzaÅe; użyj funkcji "Obraz" w sekcji "Media box")'))
+ background_plain = models.BooleanField(_('plain background'), default=False)
+ background_color = models.CharField(_('background color'), max_length=32, blank=True)
image = models.ImageField(
_('image'), upload_to='social/cite', null=True, blank=True,
help_text=_('Best image is exactly 975px wide and weights under 100kB.'))
image_shift = models.IntegerField(
_('shift'), null=True, blank=True,
- help_text=_(u'Vertical shift, in percents. 0 means top, 100 is bottom. Default is 50%.'))
+ help_text=string_concat(_('Vertical shift, in percents. 0 means top, 100 is bottom. Default is 50%.'), '
(PrzestarzaÅe; użyj obrazka o wÅaÅciwych proporcjach;)'))
image_title = models.CharField(_('title'), max_length=255, null=True, blank=True)
image_author = models.CharField(_('author'), max_length=255, blank=True, null=True)
image_link = models.URLField(_('link'), blank=True, null=True)
@@ -57,15 +74,45 @@ class Cite(models.Model):
class Meta:
ordering = ('vip', 'text')
- verbose_name = _('cite')
- verbose_name_plural = _('cites')
+ verbose_name = _('banner')
+ verbose_name_plural = _('banners')
def __str__(self):
- return u"%s: %sâ¦" % (self.vip, self.text[:60])
+ t = []
+ if self.text:
+ t.append(self.text[:60])
+ if self.book_id:
+ t.append('[ks.]'[:60])
+ t.append(self.link[:60])
+ if self.vip:
+ t.append('vip: ' + self.vip)
+ if self.picture:
+ t.append('[obr.]')
+ if self.video:
+ t.append('[vid.]')
+ return ', '.join(t)
def get_absolute_url(self):
"""This is used for testing."""
- return "%s?choose_cite=%d" % (reverse('main_page'), self.id)
+ return "%s?banner=%d" % (reverse('main_page'), self.id)
+
+ def has_box(self):
+ return self.video or self.picture
+
+ def has_body(self):
+ return self.vip or self.text or self.book
+
+ def layout(self):
+ if self.banner:
+ # TODO: move all banners to pictures.
+ return 'banner'
+ pieces = []
+ if self.has_box():
+ pieces.append('box')
+ if self.has_body():
+ pieces.append('text')
+ return '-'.join(pieces)
+
def save(self, *args, **kwargs):
ret = super(Cite, self).save(*args, **kwargs)
@@ -95,10 +142,10 @@ class Carousel(models.Model):
return self.slug
class CarouselItem(models.Model):
- order = models.PositiveSmallIntegerField(unique=True)
- carousel = models.ForeignKey(Carousel, models.CASCADE)
- banner = models.ForeignKey(Cite, models.CASCADE, null=True, blank=True)
- banner_group = models.ForeignKey(BannerGroup, models.CASCADE, null=True, blank=True)
+ order = models.PositiveSmallIntegerField(_('order'), unique=True)
+ carousel = models.ForeignKey(Carousel, models.CASCADE, verbose_name=_('carousel'))
+ banner = models.ForeignKey(Cite, models.CASCADE, null=True, blank=True, verbose_name=_('banner'))
+ banner_group = models.ForeignKey(BannerGroup, models.CASCADE, null=True, blank=True, verbose_name=_('banner group'))
class Meta:
ordering = ('order',)
@@ -114,3 +161,6 @@ class CarouselItem(models.Model):
raise ValidationError(_('Either banner or banner group is required.'))
elif self.banner and self.banner_group:
raise ValidationError(_('Either banner or banner group is required.'))
+
+ def get_banner(self):
+ return self.banner or self.banner_group.get_banner()