0

Я пытаюсь настроить формат, когда я экономлю в XLS:Ошибка пытается загрузить с помощью формата filnename

  • Я хочу, чтобы помочь пользовательская настройка = «Дата» «выбранного ejecutive» + + «.xls»

Но не работает

мои модели

class Policy < ActiveRecord::Base 
    unloadable 
    belongs_to :ejecutive 
    has_many :policy 

    def self.search(search) 
    if search 
     find(:all, :conditions => ["ejecutive_id = ? ", search.to_i ]) 
    else 
     find(:all) 
    end 
    end 
end 

class Ejecutive < ActiveRecord::Base 
    has_many :policies 
end 

Вот мой контроль Лер. Здесь я кладу формат, который я пытаюсь настроить с датой + ejecutive выбран + .xls

class PolicyManagement::PolicyController < ApplicationController 
    def generate_print_ejecutive_comercial 
     @ejecutives = Ejecutive.find(:all) 
     @search = Policy.search(params[:search]) 
     @policies = @search.paginate(:page => params[:page], :per_page =>10) 
     @results= Policy.search(params[:search]) 

     respond_to do |format| 
     format.html 
     format.xls { send_data render_to_string(:partial=>"report_by_ejecutive_xls"), :filename => "#{Date.today}#{@ejecutives.name}.xls" } 
     end 
end 

Вот мой взгляд

<% form_tag :controller=>"policy_management/policy",:action =>"generate_print_ejecutive_comercial", :method => 'get' do %> 
    <%= select_tag "search", options_for_select(@ejecutives.collect {|t| [t.name.to_s+" "+t.lastname1.to_s,t.id]}) %> 
    <%= submit_tag "Search", :name => nil %> 
<% end %> 

Results 
    <% @policies.each do |policy| %> 
    <p> <%= policy.num_policy%> </p> 
    <p> <%= policy.ejecutive.name %> </p> 
    <p> <%= policy.ejecutive.last_name %> </p> 
    <% end %> 
    <%= will_paginate @policies %> 

<%= link_to "Export", :controller=>"policy_management/policy",:action=>"generate_print_ejecutive_comercial" ,:format=>"xls",:search => params[:search],:page => params[:page] %> 

Это мой частичный вид, что я буду экспорт в первенствует

************report_by_ejecutive_xls.************** 
<% @results.each do |policy| %> 
    <%= policy.num_policy%> 
     <% if !policy.ejecutive.blank? %> 
    <%= policy.ejecutive.name %><%= policy.ejecutive.lastname1 %><%= policy.ejecutive.lastname2 %> 
     <% end %> 
<% end %> 

Я попробовал это, но только экономить первый ejecutive и я хочу только ejecutive выбран на мой взгляд

 format.xls { send_data render_to_string(:partial=>"report_by_ejecutive_xls"), :filename => "#{Date.today}#{@ejecutives.first.name}.xls" } 

Пожалуйста, кто-нибудь может помочь мне с этой проблемой?

+0

Было бы полезно увидеть представление 'report_by_ejecutive_xls'. – spickermann

+0

ok man i edit it –

ответ

1

Выбранный ejecutive объект недоступен в контроллере. Поэтому нужно реорганизовать немного, чтобы получить выбранный ejecutive в контроллере, а затем использовать его получить политику

class PolicyManagement::PolicyController < ApplicationController 
    def generate_print_ejecutive_comercial 
     @ejecutives = Ejecutive.find(:all) 

     #changed to find selected ejecutive here 
     @selected_ejecutive = Ejecutive.find_by_id(params[:search]) if params[:search] 

     # changed the search method for policies 
     @search = @selected_ejecutive.try(:policies) || Policies.scoped 

     @policies = @search.paginate(:page => params[:page], :per_page =>10) 

     # changed this line as results is same as @search 
     @results = @search 

     @ejecutive_name = @selected_ejecutive.try(:name) || "All" 

     respond_to do |format| 
     format.html 

     #changed the name here 
     format.xls { send_data render_to_string(:partial=>"report_by_ejecutive_xls"), :filename => "#{Date.today}#{@ejecutive_name}.xls" } 
     end 
end 

Там нет необходимости метода search в настоящее время.

+0

Я пробовал свой код, и у меня есть неопределенный метод 'name 'для nil: NilClass –

+0

Это действительно странно, это весь код, который у меня есть. –

+0

какой url вы используете для загрузки файла 'xls'? – tihom

 Смежные вопросы

  • Нет связанных вопросов^_^