X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/6c0f80a0b436aa78f3245c5a0b10d5d49a9a7dec..a9925ebffe713307d6bedecd670df1490aa206c8:/src/catalogue/models/collection.py?ds=inline diff --git a/src/catalogue/models/collection.py b/src/catalogue/models/collection.py index 0150055e0..f1a582cbe 100644 --- a/src/catalogue/models/collection.py +++ b/src/catalogue/models/collection.py @@ -1,25 +1,32 @@ -# -*- coding: utf-8 -*- # This file is part of Wolnelektury, licensed under GNU Affero GPLv3 or later. # Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information. # from django.conf import settings from django.db import models -from django.utils.translation import ugettext_lazy as _ -from ssify import flush_ssi_includes +from django.urls import reverse +from django.utils.translation import gettext_lazy as _ import re +from wolnelektury.utils import cached_render, clear_cached_renders class Collection(models.Model): """A collection of books, which might be defined before publishing them.""" title = models.CharField(_('title'), max_length=120, db_index=True) slug = models.SlugField(_('slug'), max_length=120, primary_key=True) - description = models.TextField(_('description'), null=True, blank=True) - - models.SlugField(_('slug'), max_length=120, unique=True, db_index=True) + description = models.TextField(_('description'), blank=True) book_slugs = models.TextField(_('book slugs')) - + authors = models.ManyToManyField( + 'Tag', + limit_choices_to={'category': 'author'}, + blank=True + ) kind = models.CharField(_('kind'), max_length=10, blank=False, default='book', db_index=True, choices=(('book', _('book')), ('picture', _('picture')))) + listed = models.BooleanField(_('listed'), default=True, db_index=True) + role = models.CharField(max_length=128, blank=True, db_index=True, choices=[ + ('', '–'), + ('recommend', _('recommended')), + ]) class Meta: ordering = ('title',) @@ -27,7 +34,7 @@ class Collection(models.Model): verbose_name_plural = _('collections') app_label = 'catalogue' - def __unicode__(self): + def __str__(self): return self.title def get_initial(self): @@ -36,26 +43,27 @@ class Collection(models.Model): except AttributeError: return '' - @models.permalink def get_absolute_url(self): - return "collection", [self.slug] + return reverse("collection", args=[self.slug]) def get_query(self): slugs = self.book_slugs.split() # allow URIs - # WTF slugs = [slug.rstrip('/').rsplit('/', 1)[-1] if '/' in slug else slug for slug in slugs] return models.Q(slug__in=slugs) def get_books(self): from catalogue.models import Book - return Book.objects.filter(self.get_query()).order_by('sort_key_author', 'sort_key') + return Book.objects.filter(self.get_query()) + + def get_5_books(self): + return self.get_books()[:5] - def flush_includes(self, languages=True): - if not languages: - return - if languages is True: - languages = [lc for (lc, _ln) in settings.LANGUAGES] + @cached_render('catalogue/collection_box.html') + def box(self): + return { + 'collection': self + } - flush_ssi_includes([ - '/katalog/%s.json' % lang for lang in languages]) + def clear_cache(self): + clear_cached_renders(self.box)