Sha256: 294a333f374750e5b37920b66ff854e7617b2a87095d0ba89e231e975a2c471c
Contents?: true
Size: 1.67 KB
Versions: 2
Compression:
Stored size: 1.67 KB
Contents
ActiveAdmin.register ReportResult do actions :show menu false member_action :excel do report_result = ReportResult.find(params[:id]) report = report_result.report result = report_result.data fields = result.first.keys package = Axlsx::Package.new do |p| p.workbook.add_worksheet(:name => "Report") do |ws| bold = ws.styles.add_style :b => true, :alignment=> {:horizontal => :center} ws.add_row fields.map{|x| report_result.human_column_name(x)}, :style => bold result.each do |r| row = [] fields.each{|f| row << report_result.human_field_value(f, r[f])} ws.add_row row end end end package.use_shared_strings = true send_data package.to_stream.read, :filename => 'report.xlsx', :type => 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' end # # SHOW # action_item :only => [:show] do link_to I18n.t('smartkiosk.admin.actions.report_results.excel'), excel_admin_report_result_path(report_result) end show do attributes_table do row :rows row :report row :created_at end panel I18n.t('smartkiosk.admin.panels.report_results.data') do report = report_result.report result = report_result.data fields = result.first.try(:keys) || [] table do tr do fields.each do |field| th report_result.human_column_name(field) end end result.each do |row| tr do fields.each do |field| td report_result.human_field_value(field, row[field]) end end end end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
smartkiosk-server-0.11.9 | app/admin/report_results.rb |
smartkiosk-server-0.11.8 | app/admin/report_results.rb |