X-Git-Url: https://git.mdrn.pl/redakcja.git/blobdiff_plain/4437d85206a7deb768c75a4fd1cb1b474e87efe3..577bb2b84d936d65bf072ef0a6b898db9d6e77ab:/apps/wiki/forms.py?ds=sidebyside diff --git a/apps/wiki/forms.py b/apps/wiki/forms.py index 7cabe325..6b10909b 100644 --- a/apps/wiki/forms.py +++ b/apps/wiki/forms.py @@ -3,11 +3,13 @@ # This file is part of FNP-Redakcja, licensed under GNU Affero GPLv3 or later. # Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information. # +from django.contrib.auth.models import User +from django.db.models import Count from django import forms -from wiki.models import Book, Chunk from django.utils.translation import ugettext_lazy as _ -from dvcs.models import Tag +from wiki.constants import MASTERS +from wiki.models import Book, Chunk class DocumentTagForm(forms.Form): """ @@ -15,7 +17,18 @@ class DocumentTagForm(forms.Form): """ id = forms.CharField(widget=forms.HiddenInput) - tag = forms.ModelChoiceField(queryset=Tag.objects.all()) + tag = forms.ModelChoiceField(queryset=Chunk.tag_model.objects.all()) + revision = forms.IntegerField(widget=forms.HiddenInput) + + +class DocumentPubmarkForm(forms.Form): + """ + Form for marking revisions for publishing. + """ + + id = forms.CharField(widget=forms.HiddenInput) + publishable = forms.BooleanField(required=False, initial=True, + label=_('Publishable')) revision = forms.IntegerField(widget=forms.HiddenInput) @@ -28,7 +41,8 @@ class DocumentCreateForm(forms.ModelForm): class Meta: model = Book - exclude = ['gallery'] + exclude = ['gallery', 'parent', 'parent_number'] + prepopulated_fields = {'slug': ['title']} def clean(self): super(DocumentCreateForm, self).clean() @@ -99,7 +113,7 @@ class DocumentTextSaveForm(forms.Form): ) stage_completed = forms.ModelChoiceField( - queryset=Tag.objects.all(), + queryset=Chunk.tag_model.objects.all(), required=False, label=_(u"Completed"), help_text=_(u"If you completed a life cycle stage, select it."), @@ -141,6 +155,10 @@ class ChunkForm(forms.ModelForm): """ Form used for editing a chunk. """ + user = forms.ModelChoiceField(queryset= + User.objects.annotate(count=Count('chunk')). + order_by('-count', 'last_name', 'first_name')) + class Meta: model = Chunk @@ -152,7 +170,7 @@ class ChunkForm(forms.ModelForm): chunk = Chunk.objects.get(book=self.instance.book, slug=slug) except Chunk.DoesNotExist: return slug - if chunk == self: + if chunk == self.instance: return slug raise forms.ValidationError(_('Chunk with this slug already exists')) @@ -179,7 +197,8 @@ class BookAppendForm(forms.Form): It means moving all chunks from book A to book B and deleting A. """ - append_to = forms.ModelChoiceField(queryset=Book.objects.all()) + append_to = forms.ModelChoiceField(queryset=Book.objects.all(), + label=_("Append to")) class BookForm(forms.ModelForm): @@ -189,3 +208,11 @@ class BookForm(forms.ModelForm): class Meta: model = Book + + +class ChooseMasterForm(forms.Form): + """ + Form used for fixing the chunks in a book. + """ + + master = forms.ChoiceField(choices=((m, m) for m in MASTERS))