X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/b2d342589a7889a3b096e7192453d53bd28eed7d..084f20588e607aa9ae3ed280b6a2f0349b6a3200:/src/funding/views.py?ds=sidebyside diff --git a/src/funding/views.py b/src/funding/views.py index ae0b1bb42..d6d6570bf 100644 --- a/src/funding/views.py +++ b/src/funding/views.py @@ -1,11 +1,10 @@ -# -*- 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.core.paginator import Paginator, InvalidPage -from django.core.urlresolvers import reverse from django.http import Http404 from django.shortcuts import get_object_or_404, redirect, render +from django.urls import reverse from django.views.decorators.csrf import csrf_exempt from django.views.generic import TemplateView, FormView, ListView from getpaid.models import Payment @@ -88,7 +87,9 @@ class OfferDetailView(FormView): raise Http404 return super(OfferDetailView, self).dispatch(request, slug) - def get_form(self, form_class): + def get_form(self, form_class=None): + if form_class is None: + form_class = self.get_form_class() if self.request.method == 'POST': return form_class(self.object, self.request.POST) else: @@ -158,11 +159,12 @@ class DisableNotifications(TemplateView): return redirect(self.request.get_full_path()) -def offer_bar(request, pk, link=False, closeable=False, show_title=True, show_title_calling=True, add_class=""): - offer = get_object_or_404(Offer, pk=pk) - offer_sum = offer.sum() - - return render(request, "funding/includes/funding.html", { +def offer_bar(offer, link=False, closeable=False, show_title=True, show_title_calling=True, add_class=""): + if offer: + offer_sum = offer.sum() + else: + return {} + return { 'offer': offer, 'sum': offer_sum, 'is_current': offer.is_current(), @@ -174,22 +176,28 @@ def offer_bar(request, pk, link=False, closeable=False, show_title=True, show_ti 'show_title': show_title, 'show_title_calling': show_title_calling, 'add_class': add_class, - }) + } + + +def render_offer_bar(request, pk, link=False, closeable=False, show_title=True, show_title_calling=True, add_class=""): + offer = get_object_or_404(Offer, pk=pk) + return render(request, "funding/includes/funding.html", + offer_bar(offer, link, closeable, show_title, show_title_calling, add_class)) @ssi_included(patch_response=[ssi_cache_control(must_revalidate=True)]) def top_bar(request, pk): - return offer_bar(request, pk, link=True, closeable=True, add_class="funding-top-header") + return render_offer_bar(request, pk, link=True, closeable=True, add_class="funding-top-header") @ssi_included(patch_response=[ssi_cache_control(must_revalidate=True)]) def list_bar(request, pk): - return offer_bar(request, pk, link=True, show_title_calling=False) + return render_offer_bar(request, pk, link=True, show_title_calling=False) @ssi_included(patch_response=[ssi_cache_control(must_revalidate=True)]) def detail_bar(request, pk): - return offer_bar(request, pk, show_title=False) + return render_offer_bar(request, pk, show_title=False) @ssi_included(patch_response=[ssi_cache_control(must_revalidate=True)])