fnp
/
wolnelektury.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Merge remote-tracking branch 'zawadzki/new-design'
[wolnelektury.git]
/
src
/
catalogue
/
models
/
collection.py
diff --git
a/src/catalogue/models/collection.py
b/src/catalogue/models/collection.py
index
0150055
..
6f956c7
100644
(file)
--- a/
src/catalogue/models/collection.py
+++ b/
src/catalogue/models/collection.py
@@
-1,12
+1,12
@@
-# -*- 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
# 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.urls import reverse
from django.utils.translation import ugettext_lazy as _
from django.utils.translation import ugettext_lazy as _
-from ssify import flush_ssi_includes
import re
import re
+from wolnelektury.utils import cached_render, clear_cached_renders
class Collection(models.Model):
class Collection(models.Model):
@@
-14,12
+14,14
@@
class Collection(models.Model):
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)
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)
book_slugs = models.TextField(_('book slugs'))
book_slugs = models.TextField(_('book slugs'))
-
kind = models.CharField(_('kind'), max_length=10, blank=False, default='book', db_index=True,
choices=(('book', _('book')), ('picture', _('picture'))))
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',)
class Meta:
ordering = ('title',)
@@
-27,7
+29,7
@@
class Collection(models.Model):
verbose_name_plural = _('collections')
app_label = 'catalogue'
verbose_name_plural = _('collections')
app_label = 'catalogue'
- def __
unicode
__(self):
+ def __
str
__(self):
return self.title
def get_initial(self):
return self.title
def get_initial(self):
@@
-36,26
+38,24
@@
class Collection(models.Model):
except AttributeError:
return ''
except AttributeError:
return ''
- @models.permalink
def get_absolute_url(self):
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
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
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 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
)