diff --git a/lib/paperclip_processors/custom_file_preview.rb b/lib/paperclip_processors/custom_file_preview.rb index c749d9e6d..f6ea765e6 100644 --- a/lib/paperclip_processors/custom_file_preview.rb +++ b/lib/paperclip_processors/custom_file_preview.rb @@ -10,16 +10,26 @@ module Paperclip dst = TempfileFactory.new.generate("#{basename}.#{options[:format]}") begin - Paperclip.run( - libreoffice_path, - "--headless --invisible --convert-to png --outdir #{directory} #{@file.path}" - ) + if @file.content_type == 'application/pdf' + # We use special convert options for PDFs to improve quality and + # background, we append [0] to convert only the first page + convert( + ":source -resize '#{options[:geometry]}' -format #{options[:format]} -flatten -quality 70 :dest", + source: File.expand_path(@file.path) + '[0]', + dest: File.expand_path(dst.path) + ) + else + Paperclip.run( + libreoffice_path, + "--headless --invisible --convert-to png --outdir #{directory} #{@file.path}" + ) - convert( - ":source -resize '#{options[:geometry]}' -format #{options[:format]} #{options[:convert_options]} :dest", - source: File.expand_path(original_preview_file), - dest: File.expand_path(dst.path) - ) + convert( + ":source -resize '#{options[:geometry]}' -format #{options[:format]} #{options[:convert_options]} :dest", + source: File.expand_path(original_preview_file), + dest: File.expand_path(dst.path) + ) + end ensure File.delete(original_preview_file) if File.file?(original_preview_file) end