X-Git-Url: https://git.mdrn.pl/redakcja.git/blobdiff_plain/18b53f03ffd1620e2f3f5b1c17e7dd12c6a6afa6..b2d61af6200bf8281e5466a183eae491440f4c1a:/apps/catalogue/forms.py diff --git a/apps/catalogue/forms.py b/apps/catalogue/forms.py index cbb1ad9d..4b6a37bb 100644 --- a/apps/catalogue/forms.py +++ b/apps/catalogue/forms.py @@ -3,6 +3,10 @@ # 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.utils.encoding import force_text +from django.utils.html import format_html +from django.utils.safestring import mark_safe + from catalogue.models import Category from catalogue.models import Tag from django import forms @@ -22,35 +26,38 @@ class DocumentCreateForm(forms.Form): """ 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) def clean_cover(self): cover = self.cleaned_data['cover'] - if cover and cover.name.rsplit('.', 1)[-1].lower() not in ('jpg', 'jpeg', 'png', 'gif', 'tif', 'tiff'): + if cover and cover.name.rsplit('.', 1)[-1].lower() not in ('jpg', 'jpeg', 'png', 'gif', 'svg'): raise forms.ValidationError(_('The cover should be an image file (jpg/png/gif)')) return file class TagForm(forms.Form): - def __init__(self, category, instance=None, *args, **kwargs): + def __init__(self, category, instance=None, tutorial_no=None, *args, **kwargs): super(TagForm, self).__init__(*args, **kwargs) self.category = category self.instance = instance self.field().queryset = Tag.objects.filter(category=self.category) - self.field().label = self.category.label + self.field().label = self.category.label.capitalize() + if tutorial_no and category.tutorial: + self.field().widget.attrs.update({ + 'data-toggle': 'tutorial', + 'data-tutorial': str(tutorial_no), + 'data-placement': 'bottom', + 'data-content': category.tutorial, + }) if self.instance: self.field().initial = self.initial() - def save(self): - assert self.instance, 'No instance provided' - self.instance.tags.remove(*self.instance.tags.filter(category=self.category)) - self.instance.tags.add(self.cleaned_tags()) + def save(self, instance=None): + instance = instance or self.instance + assert instance, 'No instance provided' + self.category.set_tags_for(instance, self.cleaned_tags()) def field(self): raise NotImplementedError @@ -61,9 +68,41 @@ class TagForm(forms.Form): def cleaned_tags(self): raise NotImplementedError + def metadata_rows(self): + return '\n'.join( + '%(value)s' % {'name': tag.category.dc_tag, 'value': tag.dc_value} + for tag in self.cleaned_tags()) + + +class TagSelect(forms.Select): + def render_option(self, selected_choices, option_value, option_label): + if option_value is None: + option_value = '' + help_html = '' + if option_value: + tag = Tag.objects.get(id=int(option_value)) + if tag.help_text: + help_html = mark_safe(' data-help="%s"' % tag.help_text) + option_value = force_text(option_value) + if option_value in selected_choices: + selected_html = mark_safe(' selected="selected"') + if not self.allow_multiple_selected: + # Only allow for a single selection. + selected_choices.remove(option_value) + else: + selected_html = '' + return format_html( + u'', + option_value, selected_html, help_html, force_text(option_label)) + class TagSingleForm(TagForm): - tag = forms.ModelChoiceField(Tag.objects.none()) + tag = forms.ModelChoiceField( + Tag.objects.none(), + widget=TagSelect(attrs={ + 'class': 'form-control', + }) + ) def field(self): return self.fields['tag'] @@ -76,7 +115,12 @@ class TagSingleForm(TagForm): class TagMultipleForm(TagForm): - tags = forms.ModelMultipleChoiceField(Tag.objects.none(), required=False) + tags = forms.ModelMultipleChoiceField( + Tag.objects.none(), required=False, + widget=forms.SelectMultiple(attrs={ + 'class': 'chosen-select', + 'data-placeholder': _('Choose'), + })) def field(self): return self.fields['tags']