X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/24721591455e048cffca365384e6759daae05916..d8a368e376f9f50ff0e3714ef716df548e86bd7f:/src/catalogue/templatetags/catalogue_tags.py diff --git a/src/catalogue/templatetags/catalogue_tags.py b/src/catalogue/templatetags/catalogue_tags.py index 8915807e1..2ca0a2d37 100644 --- a/src/catalogue/templatetags/catalogue_tags.py +++ b/src/catalogue/templatetags/catalogue_tags.py @@ -11,7 +11,7 @@ from django.template import Node, Variable, Template, Context from django.urls import reverse from django.utils.cache import add_never_cache_headers from django.utils.safestring import mark_safe -from django.utils.translation import ugettext as _ +from django.utils.translation import gettext as _ from catalogue.helpers import get_audiobook_tags from catalogue.models import Book, BookMedia, Fragment, Tag, Source @@ -401,7 +401,7 @@ def related_books(context, instance, limit=6, random=1, taken=0): @register.simple_tag -def related_books_2021(instance, limit=4, taken=0): +def related_books_2022(instance, limit=4, taken=0): limit -= taken max_books = limit @@ -424,6 +424,9 @@ def download_audio(book, daisy=True, mp3=True): if daisy and book.has_media('daisy'): for dsy in book.get_media('daisy'): links.append("%s" % (dsy.file.url, BookMedia.formats['daisy'].name)) + if daisy and book.has_media('audio.epub'): + for dsy in book.get_media('audio.epub'): + links.append("%s" % (dsy.file.url, BookMedia.formats['audio.epub'].name)) return mark_safe("".join(links)) @@ -509,7 +512,7 @@ def strip_tag(html, tag_name): def status(book, user): if not book.preview: return 'open' - elif Membership.is_active_for(user): + elif book.is_accessible_to(user): return 'preview' else: return 'closed' @@ -528,3 +531,20 @@ def content_warning(book): return { "warnings": warnings } + + +@register.inclusion_tag('catalogue/preview_ad.html', takes_context=True) +def preview_ad(context): + book = Book.objects.filter(preview=True).first() + return { + 'accessible': book.is_accessible_to(context['request'].user), + 'book': book, + } + +@register.inclusion_tag('catalogue/preview_ad_homepage.html', takes_context=True) +def preview_ad_homepage(context): + book = Book.objects.filter(preview=True).first() + return { + 'accessible': book.is_accessible_to(context['request'].user), + 'book': book, + }