我使用WickedPdf生成PDF,它在本地就像一个魅力一样...
我在Heroku上遇到麻烦。我可以下载pdf,但根本没有样式。...(在我的订单中也没有在我的贴纸中)
这是我的代码:
pdf.scss
位于vendor/assets/stylesheets
orders_controller.rb
def show
respond_to do |format|
format.html { }
format.pdf do
html = render_to_string(template: "clients/orders/show.pdf.erb", layout: "layouts/application.pdf.erb", orientation: "Landscape", page_size: 'A4', encoding:"UTF-8" )
pdf = WickedPdf.new.pdf_from_string(html)
send_data(pdf, filename: "order.pdf", type: "application/pdf", disposition: 'attachment')
end
end
end
stickers_controller.rb
def show
respond_to do |format|
format.html { }
format.pdf do
html = render_to_string(template: "admin/stickers/show.pdf.erb", layout: "layouts/application.pdf.erb", orientation: "Landscape" )
pdf = WickedPdf.new.pdf_from_string(html)
send_data(pdf, filename: "sticker.pdf", type: "application/pdf", disposition: 'attachment')
end
end
end
config / initializer / assets.rb
Rails.application.config.assets.precompile += %w( pdf.scss )
config / initializer / wicked_pdf.rb
if Rails.env.production?
WickedPdf.config = {
exe_path: Gem.bin_path('wkhtmltopdf-heroku', 'wkhtmltopdf-linux-amd64'),
page_size: 'Letter',
orientation: 'Portrait',
margin: { top: 2,
bottom: 2,
left: 2,
right: 2 }
}
else
WickedPdf.config = {
exe_path: '/usr/local/bin/wkhtmltopdf',
page_size: 'Letter',
orientation: 'Portrait',
margin: { top: 2,
bottom: 2,
left: 2,
right: 2 }
}
end
Gemfile
gem 'wicked_pdf'
gem 'wkhtmltopdf-binary', '~> 0.12.3'
gem "wkhtmltopdf-heroku"
布局/application.pdf.erb
<html lang="fr">
<head>
<meta charset="utf-8" />
<%= wicked_pdf_stylesheet_link_tag 'pdf' %>
</head>
<body>
<div>
<%= yield %>
</div>
</body>
</html>
在我的订单和贴纸中 show.pdf.erb ,我也使用引导CDN 在顶部(我在应用程序的其余部分中使用了引导程序4,但是Wickedpdf似乎不适用于引导程序4)。 Bootstrap CDN在本地工作
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" />
<div id="container">
<div class="row">
<table class="table table-striped line-items">
#the test of the code
</table>
</div>
</div>
我找到了this exemple,但它对我不起作用。 我使用的是5.2,这也许是不同的。建议添加它,但实际上它在 initializers / assets.rb
中在config/environments/production.rb
中:
config.assets.precompile += ['documents.css.scss.erb']
答案 0 :(得分:0)
所以主要的样式问题来自Bootstrap。
Bootstrap CDN链接没有完成任务,因此我最终下载了bootstap css。 基本上,我不检查所有内容,只保留需要的内容,如普通的CSS。
我缩小了引导CSS,将其粘贴到新文件bootstrap.min.css
中,并用vendor/assets/stylesheets/
将其放置在pdf.scss
下
然后我将boostrap文件导入pdf.scss中,如下所示:
@import "bootstrap.min";