user3754535 user3754535 - 1 year ago 156
Ruby Question

Rails - Ransack doesn't query

I have the folowing


belongs_to :client
belongs_to :user

has_many :line_items, dependent: :destroy
has_many :products, through: :line_items
has_many :deposits

accepts_nested_attributes_for :line_items, reject_if: :all_blank, allow_destroy: true


def index
@q = Sale.ransack(params[:q])
@sales = @q.result(distinct: true)


<%= search_form_for @q, url: admin_sales_path, html: {class: "form-inline"} do |f| %>

<%= f.search_field :sku, placeholder: "SKU", class: "input perfil" %>
<%= f.submit 'search', class: "btn btn-primary" %>

<% end %>

<table class="table">
<th><%= sort_link @q, :sku, "SKU" %></th>
<th colspan="3"></th>

<% @sales.each do |sale| %>

<% end %>

And finally this is the log from the terminal:

Started GET "/admin/sales?utf8=%E2%9C%93&q%5Bsku%5D=sample&commit=search" for ::1 at 2016-11-24 00:29:33 -0600
Processing by Admin::SalesController#index as HTML
Parameters: {"utf8"=>"✓", "q"=>{"sku"=>"sample"}, "commit"=>"search"}
Sale Load (0.3ms) SELECT DISTINCT "sales".* FROM "sales"
Rendered admin/sales/index.html.erb within layouts/admin (7.5ms)
Completed 200 OK in 361ms (Views: 346.0ms | ActiveRecord: 1.6ms)

Everything seems to work fine, but nothing seems to be filtered.

As note I apply this same method for others models and they work fine.

Answer Source

Please use this

<%= f.search_field :sku_eq, placeholder: "SKU", class: "input perfil" %>

You have a little bit mistake

Recommended from our users: Dynamic Network Monitoring from WhatsUp Gold from IPSwitch. Free Download