class_methods do
def avatar_styles(file)
- styles = { original: '120x120#' }
- styles[:static] = { format: 'png', convert_options: '-coalesce' } if file.content_type == 'image/gif'
+ styles = {}
+ geometry = Paperclip::Geometry.from_file(file)
+
+ styles[:original] = '120x120#' if geometry.width != geometry.height || geometry.width > 120 || geometry.height > 120
+ styles[:static] = { format: 'png', convert_options: '-coalesce' } if file.content_type == 'image/gif'
+
styles
+ rescue Paperclip::Errors::NotIdentifiedByImageMagickError
+ {}
end
private :avatar_styles
included do
# Avatar upload
- has_attached_file :avatar, styles: ->(f) { avatar_styles(f) }, convert_options: { all: '-quality 80 -strip' }
+ has_attached_file :avatar, styles: ->(f) { avatar_styles(f) }, convert_options: { all: '-strip' }
validates_attachment_content_type :avatar, content_type: IMAGE_MIME_TYPES
validates_attachment_size :avatar, less_than: 2.megabytes
end
class_methods do
def header_styles(file)
- styles = { original: '700x335#' }
- styles[:static] = { format: 'png', convert_options: '-coalesce' } if file.content_type == 'image/gif'
+ styles = {}
+ geometry = Paperclip::Geometry.from_file(file)
+
+ styles[:original] = '700x335#' unless geometry.width == 700 && geometry.height == 335
+ styles[:static] = { format: 'png', convert_options: '-coalesce' } if file.content_type == 'image/gif'
+
styles
+ rescue Paperclip::Errors::NotIdentifiedByImageMagickError
+ {}
end
private :header_styles
included do
# Header upload
- has_attached_file :header, styles: ->(f) { header_styles(f) }, convert_options: { all: '-quality 80 -strip' }
+ has_attached_file :header, styles: ->(f) { header_styles(f) }, convert_options: { all: '-strip' }
validates_attachment_content_type :header, content_type: IMAGE_MIME_TYPES
validates_attachment_size :header, less_than: 2.megabytes
end