stage 2: text field counter
[edumed.git] / stage2 / forms.py
index b1bcac9..8317504 100644 (file)
@@ -1,7 +1,10 @@
 # -*- coding: utf-8 -*-
+from decimal import Decimal
+
 from django import forms
-from django.conf import settings
+from django.core import validators
 from django.template.defaultfilters import filesizeformat
+from django.utils.safestring import mark_safe
 
 from stage2.models import Attachment, Mark, FieldOptionSet, FieldOption
 
@@ -13,23 +16,30 @@ class AttachmentForm(forms.ModelForm):
         model = Attachment
         fields = ['file']
 
-    def __init__(self, assignment, file_no, label, extensions=None, *args, **kwargs):
+    def __init__(self, assignment, file_no, label, options, *args, **kwargs):
         prefix = 'att%s-%s' % (assignment.id, file_no)
         super(AttachmentForm, self).__init__(*args, prefix=prefix, **kwargs)
         self.fields['assignment_id'].initial = assignment.id
-        self.fields['file'].label = label
+        extensions = options.get('ext')
+        max_mb = options.get('max', 20)
+        self.max_upload_size = max_mb * 1024 * 1024
+        self.fields['file'].widget.attrs['data-max'] = max_mb
+        label_extra = ['maks. %s MB' % max_mb]
+        if extensions:
+            label_extra.append('format: %s' % ', '.join(extensions))
+        self.fields['file'].label = label + u' (%s)' % '; '.join(label_extra)
         if extensions:
-            self.fields['file'].widget.attrs = {'data-ext': '|'.join(extensions)}
+            self.fields['file'].widget.attrs['data-ext'] = '|'.join(extensions)
         self.extensions = extensions
 
     def clean_file(self):
         file = self.cleaned_data['file']
-        if file.size > settings.MAX_UPLOAD_SIZE:
+        if file.size > self.max_upload_size:
             raise forms.ValidationError(
-                'Please keep filesize under %s. Current filesize: %s' % (
-                    filesizeformat(settings.MAX_UPLOAD_SIZE), filesizeformat(file.size)))
+                u'Prosimy o wysłanie pliku o rozmiarze najwyżej %s. Aktualny rozmiar pliku: %s' % (
+                    filesizeformat(self.max_upload_size), filesizeformat(file.size)))
         if self.extensions and ('.' not in file.name or file.name.rsplit('.', 1)[1].lower() not in self.extensions):
-            raise forms.ValidationError('Incorrect extension, should be one of: %s' % ', '.join(self.extensions))
+            raise forms.ValidationError(u'Niepoprawne rozszerzenie, powinno być jedno z: %s' % ', '.join(self.extensions))
         return file
 
 
@@ -45,12 +55,19 @@ class AssignmentFieldForm(forms.Form):
         self.fields['value'].label = label
         self.type = options['type']
         self.fields['assignment_id'].initial = answer.assignment.id
+        max_length = options.get('max_length')
+        if options.get('widget') == 'area':
+            self.fields['value'].widget = forms.Textarea(attrs={'cols': 80, 'rows': 25})
+        if max_length:
+            self.fields['value'].validators.append(validators.MaxLengthValidator(int(max_length)))
+            self.fields['value'].label += u' (maks. %s znaków)' % max_length
+            self.fields['value'].widget.attrs['data-max-length'] = max_length
         if self.type == 'options':
             option_set = FieldOptionSet.objects.get(name=options['option_set'])
             self.fields['value'].widget = forms.Select(choices=option_set.choices(answer))
-            options = answer.fieldoption_set.all()
-            if options:
-                self.fields['value'].initial = options.get().id
+            value_options = answer.fieldoption_set.all()
+            if value_options:
+                self.fields['value'].initial = value_options.get().id
         else:
             value = answer.field_values.get(label)
             self.fields['value'].initial = value or ''
@@ -91,6 +108,8 @@ class AssignmentFieldForm(forms.Form):
 
 
 class MarkForm(forms.ModelForm):
+    answer_id = forms.CharField(widget=forms.HiddenInput)
+
     class Meta:
         model = Mark
         fields = ['points']
@@ -98,15 +117,12 @@ class MarkForm(forms.ModelForm):
             'points': forms.TextInput(attrs={'type': 'number', 'min': 0, 'step': '0.5'})
         }
 
-    def __init__(self, answer, *args, **kwargs):
+    def __init__(self, answer, criterion, *args, **kwargs):
         super(MarkForm, self).__init__(*args, **kwargs)
-        self.answer = answer
-        self.fields['points'].widget.attrs['max'] = answer.assignment.max_points
-
-    def clean_points(self):
-        points = self.cleaned_data['points']
-        if points > self.answer.assignment.max_points:
-            raise forms.ValidationError('Too many points for this assignment')
-        if points < 0:
-            raise forms.ValidationError('Points cannot be negative')
-        return points
+        self.fields['answer_id'].initial = answer.id
+        points_field = self.fields['points']
+        points_field.label = mark_safe(criterion.form_label())
+        points_field.help_text = '(max %s)' % criterion.max_points
+        points_field.min_value = Decimal(0)
+        points_field.max_value = Decimal(criterion.max_points)
+        points_field.widget.attrs['max'] = criterion.max_points