X-Git-Url: https://git.mdrn.pl/redakcja.git/blobdiff_plain/840b9bd7443e0048253423f7553809b5542d731c..194720827e4a634d5ee45001e9a091e3162a7698:/apps/catalogue/forms.py?ds=sidebyside diff --git a/apps/catalogue/forms.py b/apps/catalogue/forms.py index 9d18a921..9301d9b7 100644 --- a/apps/catalogue/forms.py +++ b/apps/catalogue/forms.py @@ -3,49 +3,53 @@ # This file is part of FNP-Redakcja, licensed under GNU Affero GPLv3 or later. # Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information. # +from catalogue.models import Category from catalogue.models import User -from django.db.models import Count from django import forms from django.utils.translation import ugettext_lazy as _ from catalogue.constants import MASTERS -from catalogue.models import Book, Chunk, Template +from catalogue.models import Document -class DocumentCreateForm(forms.ModelForm): - """ - Form used for creating new documents. - """ - file = forms.FileField(required=False) - template = forms.ModelChoiceField(Template.objects, required=False) - text = forms.CharField(required=False, widget=forms.Textarea) - - class Meta: - model = Book - exclude = ['parent', 'parent_number', 'project'] - - def __init__(self, *args, **kwargs): - super(DocumentCreateForm, self).__init__(*args, **kwargs) - self.fields['slug'].widget.attrs={'class': 'autoslug'} - self.fields['gallery'].widget.attrs={'class': 'autoslug'} - self.fields['title'].widget.attrs={'class': 'autoslug-source'} - def clean(self): - super(DocumentCreateForm, self).clean() - file = self.cleaned_data['file'] - template = self.cleaned_data['template'] - - if file is not None: - try: - self.cleaned_data['text'] = file.read().decode('utf-8') - except UnicodeDecodeError: - raise forms.ValidationError(_("Text file must be UTF-8 encoded.")) - elif template is not None: - self.cleaned_data['text'] = template.content +def tag_field(category_tag, required=True): + category = Category.objects.get(dc_tag=category_tag) + return forms.ModelMultipleChoiceField(queryset=category.tag_set.all(), required=required) - if not self.cleaned_data["text"]: - self._errors["file"] = self.error_class([_("You must enter text, upload a file or select a template")]) - return self.cleaned_data +class DocumentCreateForm(forms.Form): + """ + Form used for creating new documents. + """ + owner_organization = forms.CharField(required=False) + title = forms.CharField() + language = forms.CharField() + publisher = forms.CharField(required=False) + description = forms.CharField(required=False) + rights = forms.CharField(required=False) + audience = forms.CharField() + + cover = forms.FileField(required=False) + + # summary = forms.CharField(required=True) + # template = forms.ModelChoiceField(Template.objects, required=False) + # + # def __init__(self, *args, org=None, **kwargs): + # super(DocumentCreateForm, self).__init__(*args, **kwargs) + # self.fields['title'].widget.attrs={'class': 'autoslug-source'} + # self.fields['template'].queryset = Template.objects.filter(is_main=True) + # + # def clean(self): + # super(DocumentCreateForm, self).clean() + # template = self.cleaned_data['template'] + # + # if template is not None: + # self.cleaned_data['text'] = template.content + # + # if not self.cleaned_data.get("text"): + # self._errors["template"] = self.error_class([_("You must select a template")]) + # + # return self.cleaned_data class DocumentsUploadForm(forms.Form): @@ -53,8 +57,9 @@ class DocumentsUploadForm(forms.Form): Form used for uploading new documents. """ file = forms.FileField(required=True, label=_('ZIP file')) - dirs = forms.BooleanField(label=_('Directories are documents in chunks'), - widget = forms.CheckboxInput(attrs={'disabled':'disabled'})) + dirs = forms.BooleanField( + label=_('Directories are documents in chunks'), + widget=forms.CheckboxInput(attrs={'disabled': 'disabled'})) def clean(self): file = self.cleaned_data['file'] @@ -70,92 +75,16 @@ class DocumentsUploadForm(forms.Form): return self.cleaned_data -class ChunkForm(forms.ModelForm): - """ - Form used for editing a chunk. - """ - user = forms.ModelChoiceField(queryset= - User.objects.annotate(count=Count('chunk')). - order_by('last_name', 'first_name'), required=False, - label=_('Assigned to')) - - class Meta: - model = Chunk - fields = ['title', 'slug', 'gallery_start', 'user', 'stage'] - exclude = ['number'] - - def __init__(self, *args, **kwargs): - super(ChunkForm, self).__init__(*args, **kwargs) - self.fields['gallery_start'].widget.attrs={'class': 'number-input'} - self.fields['slug'].widget.attrs={'class': 'autoslug'} - self.fields['title'].widget.attrs={'class': 'autoslug-source'} - - def clean_slug(self): - slug = self.cleaned_data['slug'] - try: - chunk = Chunk.objects.get(book=self.instance.book, slug=slug) - except Chunk.DoesNotExist: - return slug - if chunk == self.instance: - return slug - raise forms.ValidationError(_('Chunk with this slug already exists')) - - -class ChunkAddForm(ChunkForm): - """ - Form used for adding a chunk to a document. - """ - - def clean_slug(self): - slug = self.cleaned_data['slug'] - try: - user = Chunk.objects.get(book=self.instance.book, slug=slug) - except Chunk.DoesNotExist: - return slug - raise forms.ValidationError(_('Chunk with this slug already exists')) - - -class BookAppendForm(forms.Form): +class ChooseMasterForm(forms.Form): """ - Form for appending a book to another book. - It means moving all chunks from book A to book B and deleting A. + Form used for fixing the chunks in a book. """ - append_to = forms.ModelChoiceField(queryset=Book.objects.all(), - label=_("Append to")) - - def __init__(self, book, *args, **kwargs): - ret = super(BookAppendForm, self).__init__(*args, **kwargs) - self.fields['append_to'].queryset = Book.objects.exclude(pk=book.pk) - return ret - -class BookForm(forms.ModelForm): - """Form used for editing a Book.""" - - class Meta: - model = Book - exclude = ['project'] - - def __init__(self, *args, **kwargs): - ret = super(BookForm, self).__init__(*args, **kwargs) - self.fields['slug'].widget.attrs.update({"class": "autoslug"}) - self.fields['title'].widget.attrs.update({"class": "autoslug-source"}) - return ret - - -class ReadonlyBookForm(BookForm): - """Form used for not editing a Book.""" - - def __init__(self, *args, **kwargs): - ret = super(ReadonlyBookForm, self).__init__(*args, **kwargs) - for field in self.fields.values(): - field.widget.attrs.update({"readonly": True}) - return ret + master = forms.ChoiceField(choices=((m, m) for m in MASTERS)) -class ChooseMasterForm(forms.Form): +class DocumentForkForm(forms.Form): """ - Form used for fixing the chunks in a book. + Form used for forking documents. """ - - master = forms.ChoiceField(choices=((m, m) for m in MASTERS)) + owner_organization = forms.CharField(required=False)