Commit 46623fe0 authored by Ivan Tyagov's avatar Ivan Tyagov

Unhard code default image quality and make it possible to specify in...

Unhard code default image quality and make it possible to specify in preferences. Fall back to constant value as before if preference is not specified.

git-svn-id: https://svn.erp5.org/repos/public/erp5/trunk@37212 20353a03-c40f-0410-a6d1-a30d3c3de9de
parent ef9bed35
No related merge requests found
...@@ -77,8 +77,8 @@ VALID_IMAGE_FORMAT_LIST = ('jpg', 'jpeg', 'png', 'gif', 'pnm', 'ppm', 'tiff') ...@@ -77,8 +77,8 @@ VALID_IMAGE_FORMAT_LIST = ('jpg', 'jpeg', 'png', 'gif', 'pnm', 'ppm', 'tiff')
DEFAULT_DISPLAY_ID_LIST = ('nano', 'micro', 'thumbnail', DEFAULT_DISPLAY_ID_LIST = ('nano', 'micro', 'thumbnail',
'xsmall', 'small', 'medium', 'xsmall', 'small', 'medium',
'large', 'large', 'xlarge',) 'large', 'large', 'xlarge',)
# default image quality
DEFAULT_QUALITY = 75 DEFAULT_IMAGE_QUALITY = 75
DEFAULT_CONTENT_TYPE = 'text/html' DEFAULT_CONTENT_TYPE = 'text/html'
......
...@@ -44,7 +44,7 @@ from Products.ERP5Type import Permissions, PropertySheet ...@@ -44,7 +44,7 @@ from Products.ERP5Type import Permissions, PropertySheet
from Products.ERP5Type.Utils import fill_args_from_request from Products.ERP5Type.Utils import fill_args_from_request
from Products.ERP5.Document.File import File from Products.ERP5.Document.File import File
from Products.ERP5.Document.Document import Document, ConversionError,\ from Products.ERP5.Document.Document import Document, ConversionError,\
VALID_TEXT_FORMAT_LIST, DEFAULT_DISPLAY_ID_LIST, DEFAULT_QUALITY, _MARKER VALID_TEXT_FORMAT_LIST, DEFAULT_DISPLAY_ID_LIST, DEFAULT_IMAGE_QUALITY, _MARKER
from os.path import splitext from os.path import splitext
from OFS.Image import Image as OFSImage from OFS.Image import Image as OFSImage
from OFS.Image import getImageInfo from OFS.Image import getImageInfo
...@@ -185,7 +185,7 @@ class Image(TextConvertableMixin, File, OFSImage): ...@@ -185,7 +185,7 @@ class Image(TextConvertableMixin, File, OFSImage):
security.declareProtected(Permissions.View, 'tag') security.declareProtected(Permissions.View, 'tag')
def tag(self, display=None, height=None, width=None, cookie=0, def tag(self, display=None, height=None, width=None, cookie=0,
alt=None, css_class=None, format=None, quality=DEFAULT_QUALITY, alt=None, css_class=None, format=None, quality=None,
resolution=None, frame=None, **kw): resolution=None, frame=None, **kw):
"""Return HTML img tag.""" """Return HTML img tag."""
self._upradeImage() self._upradeImage()
...@@ -193,7 +193,8 @@ class Image(TextConvertableMixin, File, OFSImage): ...@@ -193,7 +193,8 @@ class Image(TextConvertableMixin, File, OFSImage):
# Get cookie if display is not specified. # Get cookie if display is not specified.
if display is None: if display is None:
display = self.REQUEST.cookies.get('display', None) display = self.REQUEST.cookies.get('display', None)
if quality is None:
quality = self.getDefaultImageQuality(format)
# display may be set from a cookie. # display may be set from a cookie.
image_size = self.getSizeFromImageDisplay(display) image_size = self.getSizeFromImageDisplay(display)
convert_kw = dict(format=format, quality=quality, resolution=resolution, convert_kw = dict(format=format, quality=quality, resolution=resolution,
...@@ -268,10 +269,12 @@ class Image(TextConvertableMixin, File, OFSImage): ...@@ -268,10 +269,12 @@ class Image(TextConvertableMixin, File, OFSImage):
return links return links
security.declareProtected(Permissions.AccessContentsInformation, 'displayMap') security.declareProtected(Permissions.AccessContentsInformation, 'displayMap')
def displayMap(self, exclude=None, format=None, quality=DEFAULT_QUALITY,\ def displayMap(self, exclude=None, format=None, quality=None,\
resolution=None): resolution=None):
"""Return list of displays with size info.""" """Return list of displays with size info."""
displays = [] displays = []
if quality is None:
quality = self.getDefaultImageQuality(format)
for id in self.displayIds(exclude): for id in self.displayIds(exclude):
if self._isGenerated(id, format=format, quality=quality,\ if self._isGenerated(id, format=format, quality=quality,\
resolution=resolution): resolution=resolution):
...@@ -331,7 +334,7 @@ class Image(TextConvertableMixin, File, OFSImage): ...@@ -331,7 +334,7 @@ class Image(TextConvertableMixin, File, OFSImage):
image_size = self.getSizeFromImageDisplay(kw.get('display')) image_size = self.getSizeFromImageDisplay(kw.get('display'))
# store all keys usefull to convert or resize an image # store all keys usefull to convert or resize an image
# 'display' parameter can be discarded # 'display' parameter can be discarded
convert_kw = {'quality': kw.get('quality', DEFAULT_QUALITY), convert_kw = {'quality': kw.get('quality', self.getDefaultImageQuality(format)),
'resolution': kw.get('resolution'), 'resolution': kw.get('resolution'),
'frame': kw.get('frame'), 'frame': kw.get('frame'),
'image_size': image_size, 'image_size': image_size,
...@@ -406,15 +409,17 @@ class Image(TextConvertableMixin, File, OFSImage): ...@@ -406,15 +409,17 @@ class Image(TextConvertableMixin, File, OFSImage):
"""Return raw photo data for given display.""" """Return raw photo data for given display."""
width, height = self._getAspectRatioSize(*image_size) width, height = self._getAspectRatioSize(*image_size)
if ((width, height) == image_size or (width, height) == (0, 0))\ if ((width, height) == image_size or (width, height) == (0, 0))\
and quality == DEFAULT_QUALITY and resolution is None and frame is None\ and quality == self.getDefaultImageQuality(format) and resolution is None and frame is None\
and not format: and not format:
# No resizing, no conversion, return raw image # No resizing, no conversion, return raw image
return self.getData() return self.getData()
return self._resize(quality, width, height, format, resolution, frame) return self._resize(quality, width, height, format, resolution, frame)
def _makeDisplayPhoto(self, format=None, quality=DEFAULT_QUALITY, def _makeDisplayPhoto(self, format=None, quality=None,
resolution=None, frame=None, image_size=None): resolution=None, frame=None, image_size=None):
"""Create given display.""" """Create given display."""
if quality is None:
quality = self.getDefaultImageQuality(format)
width, height = image_size width, height = image_size
base, ext = splitext(self.id) base, ext = splitext(self.id)
id = '%s_%s_%s.%s'% (base, width, height, ext,) id = '%s_%s_%s.%s'% (base, width, height, ext,)
...@@ -470,3 +475,11 @@ class Image(TextConvertableMixin, File, OFSImage): ...@@ -470,3 +475,11 @@ class Image(TextConvertableMixin, File, OFSImage):
""" """
File.PUT(self, REQUEST, RESPONSE) File.PUT(self, REQUEST, RESPONSE)
self._update_image_info() self._update_image_info()
def getDefaultImageQuality(self, format=None):
"""
Get default image quality for a format.
"""
preference_tool = self.getPortalObject().portal_preferences
quality = preference_tool.getPreference('preferred_image_quality', DEFAULT_IMAGE_QUALITY)
return quality
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment