2018-07-02 20:45:32 +00:00
|
|
|
# Una clase que permite adjuntar imágenes a artículos
|
|
|
|
class Post::ImageUploader < CarrierWave::Uploader::Base
|
2018-08-22 21:08:26 +00:00
|
|
|
include CarrierWave::MiniMagick
|
2018-07-02 20:45:32 +00:00
|
|
|
|
|
|
|
attr_accessor :site
|
|
|
|
|
2018-08-22 19:58:22 +00:00
|
|
|
process :strip
|
2018-08-22 20:54:55 +00:00
|
|
|
process resize_to_fit: [1280,1280]
|
2018-08-22 19:58:22 +00:00
|
|
|
|
|
|
|
version :thumb do
|
|
|
|
process :strip
|
2018-08-22 20:51:34 +00:00
|
|
|
process resize_to_fit: [200,200]
|
2018-08-22 19:58:22 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
def strip
|
|
|
|
manipulate! do |img|
|
|
|
|
img.strip
|
|
|
|
img
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-07-02 20:45:32 +00:00
|
|
|
# Necesitamos pasar el sitio para poder acceder a los archivos locales
|
|
|
|
def initialize(site)
|
|
|
|
super
|
|
|
|
|
|
|
|
@site = site
|
|
|
|
end
|
|
|
|
|
|
|
|
# Solo aceptamos imágenes
|
|
|
|
def content_type_whitelist
|
|
|
|
/\Aimage\//
|
|
|
|
end
|
|
|
|
|
|
|
|
# Devuelve la ubicación del directorio dentro de Jekyll, para eso,
|
|
|
|
# tenemos que tener acceso al sitio que estamos editando
|
|
|
|
def store_dir
|
|
|
|
File.join site.path, 'public', 'images'
|
|
|
|
end
|
|
|
|
|
|
|
|
# Almacenar en el 'tmp' local
|
|
|
|
def cache_dir
|
|
|
|
File.join Rails.root, 'tmp', 'images'
|
|
|
|
end
|
|
|
|
|
|
|
|
# XXX los nombres de los archivos siempre son únicos, no chequeamos si
|
|
|
|
# están repetidos.
|
|
|
|
def filename
|
2018-08-22 19:58:22 +00:00
|
|
|
@unique_filename ||= [SecureRandom.uuid, '.', file.extension].join
|
2018-07-02 20:45:32 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
# Obtener la URL dentro del proyecto de Jekyll
|
|
|
|
def url
|
|
|
|
CGI.unescape(super).remove site.path
|
|
|
|
end
|
|
|
|
end
|