django-extensions
[wolnelektury.git] / src / catalogue / models / collection.py
1 # -*- coding: utf-8 -*-
2 # This file is part of Wolnelektury, licensed under GNU Affero GPLv3 or later.
3 # Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information.
4 #
5 from django.conf import settings
6 from django.db import models
7 from django.utils.translation import ugettext_lazy as _
8 from ssify import flush_ssi_includes
9 import re
10
11
12 class Collection(models.Model):
13     """A collection of books, which might be defined before publishing them."""
14     title = models.CharField(_('title'), max_length=120, db_index=True)
15     slug = models.SlugField(_('slug'), max_length=120, primary_key=True)
16     description = models.TextField(_('description'), null=True, blank=True)
17
18     models.SlugField(_('slug'), max_length=120, unique=True, db_index=True)
19     book_slugs = models.TextField(_('book slugs'))
20
21     kind = models.CharField(_('kind'), max_length=10, blank=False, default='book', db_index=True, choices=((('book'), _('book')), (('picture'), ('picture'))))
22
23     class Meta:
24         ordering = ('title',)
25         verbose_name = _('collection')
26         verbose_name_plural = _('collections')
27         app_label = 'catalogue'
28
29     def __unicode__(self):
30         return self.title
31
32     def get_initial(self):
33         try:
34             return re.search(r'\w', self.title, re.U).group(0)
35         except AttributeError:
36             return ''
37
38     @models.permalink
39     def get_absolute_url(self):
40         return ("collection", [self.slug])
41
42     def get_query(self):
43         slugs = self.book_slugs.split()
44         # allow URIs
45         slugs = [slug.rstrip('/').rsplit('/', 1)[-1] if '/' in slug else slug
46                     for slug in slugs]
47         return models.Q(slug__in=slugs)
48
49     def get_books(self):
50         from catalogue.models import Book
51         return Book.objects.filter(self.get_query())
52
53     def flush_includes(self, languages=True):
54         if not languages:
55             return
56         if languages is True:
57             languages = [lc for (lc, _ln) in settings.LANGUAGES]
58
59         flush_ssi_includes([
60             '/katalog/%s.json' % lang for lang in languages])