X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/1e9113af163a3d002b0b9c3e8c339f22af5b848a..da000570285d53adef7dd9d799ee49398e0e370b:/apps/catalogue/templatetags/catalogue_tags.py?ds=sidebyside diff --git a/apps/catalogue/templatetags/catalogue_tags.py b/apps/catalogue/templatetags/catalogue_tags.py index e80a5ffe6..c9bf3dda2 100644 --- a/apps/catalogue/templatetags/catalogue_tags.py +++ b/apps/catalogue/templatetags/catalogue_tags.py @@ -366,8 +366,8 @@ def book_mini(book, with_link=True): def work_list(context, object_list): request = context.get('request') for obj in object_list: - obj.object_type = type(object_list[0]).__name__ - + obj.object_type = type(obj).__name__ + return locals() @@ -388,17 +388,14 @@ def fragment_promo(arg=None): @register.inclusion_tag('catalogue/related_books.html') -def related_books(book, limit=6, random=1): +def related_books(book, limit=6, random=1, taken=0): + limit = limit - taken cache_key = "catalogue.related_books.%d.%d" % (book.id, limit - random) related = cache.get(cache_key) if related is None: - related = list(Book.objects.filter( - common_slug=book.common_slug).exclude(pk=book.pk)[:limit]) - limit -= len(related) - if limit > random: - related += Book.tagged.related_to(book, - Book.objects.exclude(common_slug=book.common_slug), - ignore_by_tag=book.book_tag())[:limit-random] + related = Book.tagged.related_to(book, + Book.objects.exclude(common_slug=book.common_slug), + ignore_by_tag=book.book_tag())[:limit-random] cache.set(cache_key, related, 1800) if random: random_books = Book.objects.exclude( @@ -421,7 +418,7 @@ def catalogue_menu(): ('genre', _('Genres'), 'gatunki'), ('kind', _('Kinds'), 'rodzaje'), ('epoch', _('Epochs'), 'epoki'), - ('theme', _('Themes'), 'autorzy'), + ('theme', _('Themes'), 'motywy'), ]}