X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/beb5154606f790915bc56b9cb8af824537cc7d7a..94648e7ec0f755a99251bb47389eedf934aa5d3e:/src/social/templatetags/social_tags.py diff --git a/src/social/templatetags/social_tags.py b/src/social/templatetags/social_tags.py index 90ed51817..193a1ce3a 100644 --- a/src/social/templatetags/social_tags.py +++ b/src/social/templatetags/social_tags.py @@ -5,36 +5,37 @@ import re from django import template from django.utils.functional import lazy from django.utils.cache import add_never_cache_headers -from catalogue.models import Book -from ssify import ssi_variable -from ssify.utils import ssi_vary_on_cookie -from social.utils import likes, get_or_choose_cite +from catalogue.models import Book, Fragment +from social.utils import likes, get_or_choose_cite, choose_cite as cs from ..models import Carousel, Cite register = template.Library() -@ssi_variable(register, patch_response=[ssi_vary_on_cookie]) -def likes_book(request, book_id): - return likes(request.user, Book.objects.get(pk=book_id), request) +@register.simple_tag(takes_context=True) +def likes_book(context, book): + request = context['request'] + return likes(request.user, book, request) -@ssi_variable(register, name='choose_cite', patch_response=[add_never_cache_headers]) -def choose_cite_tag(request, book_id=None, tag_ids=None): - cite = get_or_choose_cite(request, book_id, tag_ids) - return cite.pk if cite is not None else None +@register.simple_tag(takes_context=True) +def choose_cite(context, book_id=None, tag_ids=None): + request = context['request'] + return get_or_choose_cite(request, book_id, tag_ids) -@register.inclusion_tag('social/cite_promo.html') -def render_cite(cite): - return { - 'cite': cite, - } +@register.simple_tag +def choose_cites(number, book=None, author=None): + if book is not None: + return book.choose_fragments(number) # todo: cites? + elif author is not None: + return Fragment.tagged.with_all([author]).order_by('?')[:number] -@ssi_variable(register, patch_response=[ssi_vary_on_cookie]) -def book_shelf_tags(request, book_id): - if not request.user.is_authenticated(): +@register.simple_tag(takes_context=True) +def book_shelf_tags(context, book_id): + request = context['request'] + if not request.user.is_authenticated: return '' book = Book.objects.get(pk=book_id) lks = likes(request.user, book, request) @@ -51,13 +52,8 @@ def book_shelf_tags(request, book_id): @register.inclusion_tag('social/carousel.html', takes_context=True) -def carousel(context, slug): - # TODO: cache - try: - carousel = Carousel.objects.get(slug=slug) - except Carousel.DoesNotExist: - # TODO: add sanity check for install. - carousel = None +def carousel(context, placement): + carousel = Carousel.get(placement) banners = [ item.get_banner() for item in carousel.carouselitem_set.all().select_related('banner') @@ -89,6 +85,14 @@ def carousel(context, slug): } +@register.inclusion_tag('social/carousel_2022.html', takes_context=True) +def carousel_2022(context, placement): + banner = Carousel.get(placement).carouselitem_set.first().get_banner() + return { + 'banner': banner, + } + + @register.inclusion_tag('social/embed_video.html') def embed_video(url): m = re.match(r'https://www.youtube.com/watch\?v=([^&;]+)', url)