fnp
/
redakcja.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Metadata editor
[redakcja.git]
/
src
/
cover
/
forms.py
diff --git
a/src/cover/forms.py
b/src/cover/forms.py
old mode 100755
(executable)
new mode 100644
(file)
index
513bdef
..
ee82a5a
--- a/
src/cover/forms.py
+++ b/
src/cover/forms.py
@@
-1,27
+1,31
@@
-# -*- coding: utf-8 -*-
-#
# This file is part of FNP-Redakcja, licensed under GNU Affero GPLv3 or later.
# Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information.
#
# This file is part of FNP-Redakcja, licensed under GNU Affero GPLv3 or later.
# Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information.
#
-from
StringIO import String
IO
+from
io import Bytes
IO
from django import forms
from django.conf import settings
from django.utils.translation import ugettext_lazy as _, ugettext
from cover.models import Image
from django import forms
from django.conf import settings
from django.utils.translation import ugettext_lazy as _, ugettext
from cover.models import Image
-from django.utils.
text
import mark_safe
+from django.utils.
safestring
import mark_safe
from PIL import Image as PILImage
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):
class Meta:
model = Image
class ImageAddForm(forms.ModelForm):
class Meta:
model = Image
+ exclude = []
def __init__(self, *args, **kwargs):
super(ImageAddForm, self).__init__(*args, **kwargs)
self.fields['file'].required = False
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
def clean_download_url(self):
cl = self.cleaned_data['download_url'] or None
@@
-42,10
+46,15
@@
class ImageAddForm(forms.ModelForm):
same_source = Image.objects.filter(source_url=source_url)
if same_source:
raise forms.ValidationError(mark_safe(
same_source = Image.objects.filter(source_url=source_url)
if same_source:
raise forms.ValidationError(mark_safe(
- ugettext('Image <a href="%
s">already in repository</a>'
-
% same_source.first().get_absolute_url())
))
+ ugettext('Image <a href="%
(url)s">already in repository</a>.')
+
% {'url': same_source.first().get_absolute_url()}
))
return source_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)
def clean(self):
cleaned_data = super(ImageAddForm, self).clean()
download_url = cleaned_data.get('download_url', None)
@@
-54,7
+63,7
@@
class ImageAddForm(forms.ModelForm):
raise forms.ValidationError(ugettext('No image specified'))
if download_url:
image_data = URLOpener().open(download_url).read()
raise forms.ValidationError(ugettext('No image specified'))
if download_url:
image_data = URLOpener().open(download_url).read()
- width, height = PILImage.open(
String
IO(image_data)).size
+ width, height = PILImage.open(
Bytes
IO(image_data)).size
else:
width, height = PILImage.open(uploaded_file.file).size
min_width, min_height = settings.MIN_COVER_SIZE
else:
width, height = PILImage.open(uploaded_file.file).size
min_width, min_height = settings.MIN_COVER_SIZE
@@
-92,15
+101,16
@@
class ReadonlyImageEditForm(ImageEditForm):
raise AssertionError("ReadonlyImageEditForm should not be saved.")
raise AssertionError("ReadonlyImageEditForm should not be saved.")
-class
Flickr
Form(forms.Form):
- source_url = forms.URLField(label=_('
Flickr
URL'))
+class
Import
Form(forms.Form):
+ source_url = forms.URLField(label=_('
WikiCommons, MNW, Flickr, RawPixel
URL'))
def clean_source_url(self):
url = self.cleaned_data['source_url']
try:
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'):
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']
+