diff options
author | Matt Jankowski <mjankowski@thoughtbot.com> | 2017-05-05 15:37:02 -0400 |
---|---|---|
committer | Eugen Rochko <eugen@zeonfederated.com> | 2017-05-05 21:37:02 +0200 |
commit | 4e057513466884050eb17b0d3c4b091852399ee4 (patch) | |
tree | f81bec456acb0737dac53b4c0104922740b83bef /app/models/concerns | |
parent | ee3e0a93f43d7236928dc2dd63361b69cd7883ee (diff) |
Move account header and avatar methods to a concern (#2825)
Diffstat (limited to 'app/models/concerns')
-rw-r--r-- | app/models/concerns/account_avatar.rb | 41 | ||||
-rw-r--r-- | app/models/concerns/account_header.rb | 41 |
2 files changed, 82 insertions, 0 deletions
diff --git a/app/models/concerns/account_avatar.rb b/app/models/concerns/account_avatar.rb new file mode 100644 index 000000000..38e32864a --- /dev/null +++ b/app/models/concerns/account_avatar.rb @@ -0,0 +1,41 @@ +# frozen_string_literal: true + +module AccountAvatar + extend ActiveSupport::Concern + IMAGE_MIME_TYPES = ['image/jpeg', 'image/png', 'image/gif'].freeze + + class_methods do + def avatar_styles(file) + styles = { original: '120x120#' } + styles[:static] = { format: 'png' } if file.content_type == 'image/gif' + styles + end + private :avatar_styles + end + + included do + # Avatar upload + has_attached_file :avatar, styles: ->(f) { avatar_styles(f) }, convert_options: { all: '-quality 80 -strip' } + validates_attachment_content_type :avatar, content_type: IMAGE_MIME_TYPES + validates_attachment_size :avatar, less_than: 2.megabytes + + def avatar_original_url + avatar.url(:original) + end + + def avatar_static_url + avatar_content_type == 'image/gif' ? avatar.url(:static) : avatar_original_url + end + + def avatar_remote_url=(url) + parsed_url = Addressable::URI.parse(url).normalize + + return if !%w(http https).include?(parsed_url.scheme) || parsed_url.host.empty? || self[:avatar_remote_url] == url + + self.avatar = URI.parse(parsed_url.to_s) + self[:avatar_remote_url] = url + rescue OpenURI::HTTPError => e + Rails.logger.debug "Error fetching remote avatar: #{e}" + end + end +end diff --git a/app/models/concerns/account_header.rb b/app/models/concerns/account_header.rb new file mode 100644 index 000000000..8fa5e1616 --- /dev/null +++ b/app/models/concerns/account_header.rb @@ -0,0 +1,41 @@ +# frozen_string_literal: true + +module AccountHeader + extend ActiveSupport::Concern + IMAGE_MIME_TYPES = ['image/jpeg', 'image/png', 'image/gif'].freeze + + class_methods do + def header_styles(file) + styles = { original: '700x335#' } + styles[:static] = { format: 'png' } if file.content_type == 'image/gif' + styles + end + private :header_styles + end + + included do + # Header upload + has_attached_file :header, styles: ->(f) { header_styles(f) }, convert_options: { all: '-quality 80 -strip' } + validates_attachment_content_type :header, content_type: IMAGE_MIME_TYPES + validates_attachment_size :header, less_than: 2.megabytes + + def header_original_url + header.url(:original) + end + + def header_static_url + header_content_type == 'image/gif' ? header.url(:static) : header_original_url + end + + def header_remote_url=(url) + parsed_url = Addressable::URI.parse(url).normalize + + return if !%w(http https).include?(parsed_url.scheme) || parsed_url.host.empty? || self[:header_remote_url] == url + + self.header = URI.parse(parsed_url.to_s) + self[:header_remote_url] = url + rescue OpenURI::HTTPError => e + Rails.logger.debug "Error fetching remote header: #{e}" + end + end +end |