Removed that annoying banner ;) Next year, make this an admin option.
[wolnelektury.git] / apps / catalogue / forms.py
index 6506deb..bf6b0df 100644 (file)
@@ -2,8 +2,16 @@
 from django import forms
 from slughifi import slughifi
 
 from django import forms
 from slughifi import slughifi
 
-from catalogue.models import Tag
+from catalogue.models import Tag, Book
 from catalogue.fields import JQueryAutoCompleteField
 from catalogue.fields import JQueryAutoCompleteField
+from catalogue import utils
+
+
+class BookImportForm(forms.Form):
+    book_xml_file = forms.FileField()
+
+    def save(self, commit=True):
+        return Book.from_xml_file(self.cleaned_data['book_xml_file'], overwrite=True)
 
 
 class SearchForm(forms.Form):
 
 
 class SearchForm(forms.Form):
@@ -13,7 +21,7 @@ class SearchForm(forms.Form):
     def __init__(self, *args, **kwargs):
         tags = kwargs.pop('tags', [])
         super(SearchForm, self).__init__(*args, **kwargs)
     def __init__(self, *args, **kwargs):
         tags = kwargs.pop('tags', [])
         super(SearchForm, self).__init__(*args, **kwargs)
-        self.fields['q'].widget.attrs['title'] = u'tytuł, autor, motyw, epoka, rodzaj, gatunek literacki'
+        self.fields['q'].widget.attrs['title'] = u'tytuł, autor, motyw/temat, epoka, rodzaj, gatunek'
         self.fields['tags'].initial = '/'.join(tag.slug for tag in Tag.get_tag_list(tags))
 
 
         self.fields['tags'].initial = '/'.join(tag.slug for tag in Tag.get_tag_list(tags))
 
 
@@ -31,7 +39,7 @@ class ObjectSetsForm(forms.Form):
         self.fields['set_ids'] = forms.MultipleChoiceField(
             label=u'Półki',
             required=False,
         self.fields['set_ids'] = forms.MultipleChoiceField(
             label=u'Półki',
             required=False,
-            choices=[(tag.id, tag.name) for tag in Tag.objects.filter(category='set', user=user)],
+            choices=[(tag.id, "%s (%s)" % (tag.name, tag.book_count)) for tag in Tag.objects.filter(category='set', user=user)],
             initial=[tag.id for tag in obj.tags.filter(category='set', user=user)],
             widget=forms.CheckboxSelectMultiple
         )
             initial=[tag.id for tag in obj.tags.filter(category='set', user=user)],
             widget=forms.CheckboxSelectMultiple
         )
@@ -46,9 +54,25 @@ class NewSetForm(forms.Form):
         
     def save(self, user, commit=True):
         name = self.cleaned_data['name']
         
     def save(self, user, commit=True):
         name = self.cleaned_data['name']
-        new_set = Tag(name=name, slug=slughifi(name), sort_key=slughifi(name),
+        new_set = Tag(name=name, slug=utils.get_random_hash(name), sort_key=slughifi(name),
             category='set', user=user)
         
         new_set.save()
         return new_set
 
             category='set', user=user)
         
         new_set.save()
         return new_set
 
+
+FORMATS = (
+    ('mp3', 'MP3'),
+    ('ogg', 'OGG'),
+    ('pdf', 'PDF'),
+    ('odt', 'ODT'),
+    ('txt', 'TXT'),
+)
+
+
+class DownloadFormatsForm(forms.Form):
+    formats = forms.MultipleChoiceField(required=False, choices=FORMATS, widget=forms.CheckboxSelectMultiple)
+    
+    def __init__(self, *args, **kwargs):
+         super(DownloadFormatsForm, self).__init__(*args, **kwargs)
+