X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/357027375ff8867f42ca34bcbfb5a78b5b185fc3..f0c1ca86983a56a80796a10499033304dd3a8c0e:/src/catalogue/forms.py?ds=inline diff --git a/src/catalogue/forms.py b/src/catalogue/forms.py index d52310bd3..100f79496 100644 --- a/src/catalogue/forms.py +++ b/src/catalogue/forms.py @@ -1,9 +1,8 @@ -# -*- 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 import forms -from django.utils.translation import ugettext_lazy as _ +from django.utils.translation import gettext_lazy as _ from catalogue.models import Book from waiter.models import WaitedFile @@ -15,6 +14,9 @@ from catalogue.tasks import build_custom_pdf class BookImportForm(forms.Form): book_xml_file = forms.FileField(required=False) book_xml = forms.CharField(required=False) + gallery_url = forms.CharField(required=False) + days = forms.IntegerField(required=False) + hidden = forms.BooleanField(required=False) def clean(self): from django.core.files.base import ContentFile @@ -22,47 +24,52 @@ class BookImportForm(forms.Form): if not self.cleaned_data['book_xml_file']: if self.cleaned_data['book_xml']: self.cleaned_data['book_xml_file'] = \ - ContentFile(self.cleaned_data['book_xml'].encode('utf-8')) + ContentFile(self.cleaned_data['book_xml'].encode('utf-8')) else: - raise forms.ValidationError(_("Please supply an XML.")) + raise forms.ValidationError("Proszę podać XML.") return super(BookImportForm, self).clean() - def save(self, commit=True, **kwargs): - return Book.from_xml_file(self.cleaned_data['book_xml_file'], overwrite=True, **kwargs) + def save(self, **kwargs): + return Book.from_xml_file(self.cleaned_data['book_xml_file'], overwrite=True, + remote_gallery_url=self.cleaned_data['gallery_url'], + days=self.cleaned_data['days'], + findable=not self.cleaned_data['hidden'], + **kwargs) FORMATS = [(f, f.upper()) for f in Book.ebook_formats] class DownloadFormatsForm(forms.Form): - formats = forms.MultipleChoiceField(required=False, choices=FORMATS, - widget=forms.CheckboxSelectMultiple) + formats = forms.MultipleChoiceField(required=False, choices=FORMATS, widget=forms.CheckboxSelectMultiple) def __init__(self, *args, **kwargs): super(DownloadFormatsForm, self).__init__(*args, **kwargs) CUSTOMIZATION_FLAGS = ( - ('nofootnotes', _("Don't show footnotes")), - ('nothemes', _("Don't disply themes")), - ('nowlfont', _("Don't use our custom font")), - ('no-cover', _("Without cover")), + ('nofootnotes', _("Bez przypisów")), + ('nothemes', _("Bez motywów")), + ('nowlfont', _("Bez naszego kroju pisma")), + ('nocover', _("Bez okładki")), + ('notoc', _("Bez spisu treści")), ) CUSTOMIZATION_OPTIONS = ( - ('leading', _("Leading"), ( - ('', _('Normal leading')), - ('onehalfleading', _('One and a half leading')), - ('doubleleading', _('Double leading')), - )), - ('fontsize', _("Font size"), ( - ('', _('Default')), - ('13pt', _('Big')) - )), -# ('pagesize', _("Paper size"), ( -# ('a4paper', _('A4')), -# ('a5paper', _('A5')), -# )), - ) + ('leading', _("Interlinia"), ( + ('', _('Zwykła interlinia')), + ('onehalfleading', _('Powiększona interlinia')), + ('doubleleading', _('Podwójna interlinia')), + )), + ('fontsize', _("Rozmiar tekstu"), ( + ('', _('Domyślny')), + ('13pt', _('Duży')), + ('16pt', _('Większy')), + )), + # ('pagesize', _("Rozmiar papieru"), ( + # ('a4paper', _('A4')), + # ('a5paper', _('A5')), + # )), +) class CustomPDFForm(forms.Form): @@ -72,14 +79,13 @@ class CustomPDFForm(forms.Form): for name, label in CUSTOMIZATION_FLAGS: self.fields[name] = forms.BooleanField(required=False, label=label) for name, label, choices in CUSTOMIZATION_OPTIONS: - self.fields[name] = forms.ChoiceField(choices, required=False, label=label) + self.fields[name] = forms.ChoiceField(choices=choices, required=False, label=label) def clean(self): self.cleaned_data['cust'] = self.customizations - self.cleaned_data['path'] = get_customized_pdf_path(self.book, - self.cleaned_data['cust']) + self.cleaned_data['path'] = get_customized_pdf_path(self.book, self.cleaned_data['cust']) if not WaitedFile.can_order(self.cleaned_data['path']): - raise ValidationError(_('Queue is full. Please try again later.')) + raise ValidationError(_('Kolejka jest pełna. Proszę spróbować ponownie później.')) return self.cleaned_data @property @@ -98,11 +104,10 @@ class CustomPDFForm(forms.Form): def save(self, *args, **kwargs): if not self.cleaned_data['cust'] and self.book.pdf_file: # Don't build with default options, just redirect to the standard file. - return {"redirect": self.book.pdf_file.url} - url = WaitedFile.order(self.cleaned_data['path'], - lambda p, waiter_id: build_custom_pdf.delay(self.book.id, - self.cleaned_data['cust'], p, waiter_id), + return {"redirect": self.book.pdf_url()} + url = WaitedFile.order( + self.cleaned_data['path'], + lambda p, waiter_id: build_custom_pdf.delay(self.book.id, self.cleaned_data['cust'], p, waiter_id), self.book.pretty_title() - ) - #return redirect(url) + ) return {"redirect": url}