Wicked-PDF рендеринг изображений с помощью Rails Active Storage - PullRequest
0 голосов
/ 06 июня 2018

Я не могу получить wicked_pdf для отображения изображения из активного хранилища в файл PDF.Должен ли я использовать: wicked_pdf_image_tag или wicked_pdf_asset_base64 или просто image_tag в шаблоне PDF.Тогда я даю rails_blob_path(company.logo) или просто company.logo любому другому методу?

Ответы [ 2 ]

0 голосов
/ 28 июля 2018

Я использую service_url вот так

image_tag(company.logo.service_url)

Больше информации здесь: https://api.rubyonrails.org/v5.2.0/classes/ActiveStorage/Variant.html#method-i-service_url

0 голосов
/ 03 июля 2018

Продолжается работа по добавлению поддержки Active Storage к wicked_pdf в этой теме выпуска GitHub

Пока это не добавлено (вы можете помочь!), Вы можете создать помощникаметод, похожий на этот (который является слегка измененной версией примера из ветки выше):

# Use like `image_tag(wicked_active_storage_asset(user.avatar))`
def wicked_active_storage_asset(asset)
  return unless asset.respond_to?(:blob)
  save_path = Rails.root.join('tmp', asset.id)
  File.open(save_path, 'wb') do |file|
    file << asset.blob.download
  end
  save_path.to_s
end

Или, если вы можете использовать веб-ресурсы непосредственно в процессе создания PDF:

<img src="<%= @user.avatar.service_url %>">
<img src="<%= @user.avatar.variant(resize: "590").processed.service_url %>">
...