X-Git-Url: https://git.mdrn.pl/redakcja.git/blobdiff_plain/a6767b2d034dcf53d6e88b3e0b6eadfebc5adab1..35c2cc82e299b9ed2c427d8ee7ae072deddcef6d:/src/cover/forms.py
diff --git a/src/cover/forms.py b/src/cover/forms.py
index ea51e46b..ee82a5af 100644
--- a/src/cover/forms.py
+++ b/src/cover/forms.py
@@ -10,7 +10,7 @@ from cover.models import Image
from django.utils.safestring import mark_safe
from PIL import Image as PILImage
-from cover.utils import get_flickr_data, FlickrError, URLOpener
+from cover.utils import get_import_data, FlickrError, URLOpener
class ImageAddForm(forms.ModelForm):
@@ -21,6 +21,11 @@ class ImageAddForm(forms.ModelForm):
def __init__(self, *args, **kwargs):
super(ImageAddForm, self).__init__(*args, **kwargs)
self.fields['file'].required = False
+ self.fields['use_file'].required = False
+ self.fields['cut_top'].required = False
+ self.fields['cut_left'].required = False
+ self.fields['cut_bottom'].required = False
+ self.fields['cut_right'].required = False
def clean_download_url(self):
cl = self.cleaned_data['download_url'] or None
@@ -41,10 +46,15 @@ class ImageAddForm(forms.ModelForm):
same_source = Image.objects.filter(source_url=source_url)
if same_source:
raise forms.ValidationError(mark_safe(
- ugettext('Image already in repository'
- % same_source.first().get_absolute_url())))
+ ugettext('Image already in repository.')
+ % {'url': same_source.first().get_absolute_url()}))
return source_url
+ clean_cut_top = lambda self: self.cleaned_data.get('cut_top') or 0
+ clean_cut_bottom = lambda self: self.cleaned_data.get('cut_bottom') or 0
+ clean_cut_left = lambda self: self.cleaned_data.get('cut_left') or 0
+ clean_cut_right = lambda self: self.cleaned_data.get('cut_right') or 0
+
def clean(self):
cleaned_data = super(ImageAddForm, self).clean()
download_url = cleaned_data.get('download_url', None)
@@ -91,15 +101,16 @@ class ReadonlyImageEditForm(ImageEditForm):
raise AssertionError("ReadonlyImageEditForm should not be saved.")
-class FlickrForm(forms.Form):
- source_url = forms.URLField(label=_('Flickr URL'))
+class ImportForm(forms.Form):
+ source_url = forms.URLField(label=_('WikiCommons, MNW, Flickr, RawPixel URL'))
def clean_source_url(self):
url = self.cleaned_data['source_url']
try:
- flickr_data = get_flickr_data(url)
+ import_data = get_import_data(url)
except FlickrError as e:
raise forms.ValidationError(e)
for field_name in ('license_url', 'license_name', 'author', 'title', 'download_url'):
- self.cleaned_data[field_name] = flickr_data[field_name]
- return flickr_data['source_url']
+ self.cleaned_data[field_name] = import_data[field_name]
+ return import_data['source_url']
+