X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/ae60b2a3949e96357477cc04f90fd0873cee8a92..bbf9e601991d5d90ed55ee9d5c9d3018afc95d3a:/src/social/views.py diff --git a/src/social/views.py b/src/social/views.py index 49c9b708a..e3d60ca93 100644 --- a/src/social/views.py +++ b/src/social/views.py @@ -1,19 +1,16 @@ -# -*- 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. +# This file is part of Wolne Lektury, licensed under GNU Affero GPLv3 or later. +# Copyright © Fundacja Wolne Lektury. See NOTICE for more information. # from django.shortcuts import render, get_object_or_404, redirect from django.http import HttpResponseForbidden, JsonResponse from django.contrib.auth.decorators import login_required +from django.views.decorators.cache import never_cache from django.views.decorators.http import require_POST - -from ajaxable.utils import AjaxableFormView +from django.views.generic.edit import FormView from catalogue.models import Book -from ssify import ssi_included -from social import forms -from .models import Cite -from social.utils import get_set, likes, set_sets +from social import forms, models +from wolnelektury.utils import is_ajax # ==================== @@ -23,68 +20,113 @@ from social.utils import get_set, likes, set_sets @require_POST def like_book(request, slug): - if not request.user.is_authenticated(): + if not request.user.is_authenticated: return HttpResponseForbidden('Login required.') book = get_object_or_404(Book, slug=slug) - if not likes(request.user, book): - tag = get_set(request.user, '') - set_sets(request.user, book, [tag]) - if request.is_ajax(): + models.UserList.like(request.user, book) + + if is_ajax(request): return JsonResponse({"success": True, "msg": "ok", "like": True}) else: return redirect(book) -@login_required -def my_shelf(request): - books = Book.tagged.with_any(request.user.tag_set.all()) - return render(request, 'social/my_shelf.html', locals()) - +class AddSetView(FormView): + form_class = forms.AddSetForm + template_name = 'forms/form_detail.html' -class ObjectSetsFormView(AjaxableFormView): - form_class = forms.ObjectSetsForm - placeholdize = True - template = 'social/sets_form.html' - ajax_redirect = True - POST_login = True + def form_valid(self, form): + book, tag = form.save(self.request.user) - def get_object(self, request, slug): - return get_object_or_404(Book, slug=slug) + if is_ajax(self.request): + return JsonResponse(get_sets_for_book_ids([book.id], self.request.user)) + else: + return redirect(book) - def context_description(self, request, obj): - return obj.pretty_title() - def form_args(self, request, obj): - return (obj, request.user), {} +class RemoveSetView(AddSetView): + form_class = forms.RemoveSetForm @require_POST def unlike_book(request, slug): - if not request.user.is_authenticated(): + if not request.user.is_authenticated: return HttpResponseForbidden('Login required.') book = get_object_or_404(Book, slug=slug) - if likes(request.user, book): - set_sets(request.user, book, []) - if request.is_ajax(): + models.UserList.unlike(request.user, book) + + if is_ajax(request): return JsonResponse({"success": True, "msg": "ok", "like": False}) else: return redirect(book) -@ssi_included -def cite(request, pk, main=False): - cite = get_object_or_404(Cite, pk=pk) - return render(request, 'social/cite_promo.html', { - 'main': main, - 'cite': cite, +@login_required +def my_shelf(request): + template_name = 'social/my_shelf.html' + ulists = list(request.user.userlist_set.all()) + suggest = [t for t in ulists if t.name] + + return render(request, template_name, { + 'tags': ulists, + 'books': Book.objects_filter(userlistitem__list__user=request.user), + 'suggest': suggest, }) -@ssi_included(use_lang=False) -def cite_info(request, pk): - cite = get_object_or_404(Cite, pk=pk) - return render(request, 'social/cite_info.html', { - 'cite': cite, +def get_sets_for_book_ids(book_ids, user): + data = {} + tagged = models.UserListItem.objects.filter( + list__user=user, + book_id__in=book_ids + ).order_by('list__name') + for t in tagged: + item = data.setdefault(t.book_id, []) + if t.list.name: + item.append({ + "slug": t.list.slug, + "url": t.list.get_absolute_url(), + "name": t.list.name, + }) + for b in book_ids: + if b not in data: + data[b] = None + return data + + + + +@never_cache +def my_liked(request): + if not request.user.is_authenticated: + return JsonResponse({}) + try: + ids = [int(x) for x in request.GET.get('ids', '').split(',')] + except: + return JsonResponse({}) + return JsonResponse(get_sets_for_book_ids(ids, request.user)) + + +@never_cache +@login_required +def my_tags(request): + term = request.GET.get('term', '') + tags = models.UserList.objects.filter(user=request.user).order_by('name') + if term: + ulists = tags.filter(name__icontains=term) + return JsonResponse( + [ + ul.name for ul in ulists + ], safe=False + ) + + +def confirm_user(request, key): + uc = get_object_or_404(models.UserConfirmation, key=key) + user = uc.user + uc.use() + return render(request, 'social/user_confirmation.html', { + 'user': user, })