I am trying to add filterrific to my rails app. I followed this tutorial but my live update is not working. I need to hit refresh to update the results in my view. I tried looking for solution and found some links (Link 1, Link 2), but no success. Below is my code.
agent.rb
class Agent < ApplicationRecord
STATUS_ACTIVE = 'ACTIVE'.freeze
STATUS_INACTIVE = 'INACTIVE'.freeze
filterrific(
default_filter_params: { sorted_by: 'name_asc' },
available_filters: [
:sorted_by,
:search_query,
:with_agent_id,
]
)
scope :sorted_by, lambda { |sort_option|
direction = /desc$/.match?(sort_option) ? "desc" : "asc"
case sort_option.to_s
when /^name/
order("name #{direction}")
when /^location/
order("location #{direction}")
else
raise(ArgumentError, "Invalid sort option: #{sort_option.inspect}")
end
}
scope :search_query, lambda { |query|
# Filters students whose name or email matches the query
}
scope :with_agent_id, lambda { |agent_ids|
where(id: agent_ids)
}
# This method provides select options for the `sorted_by` filter select input.
# It is called in the controller as part of `initialize_filterrific`.
def self.options_for_sorted_by
[
["Name (a-z)", "name_asc"],
["Name (z-a)", "name_desc"],
["Location (a-z)", "location_asc"],
]
end
end
AgentsController/index.html.erb
def index
@filterrific = initialize_filterrific(
Agent,
params[:filterrific],
select_options: {
sorted_by: Agent.options_for_sorted_by,
},
persistence_id: true,
default_filter_params: {},
available_filters: [:sorted_by],
sanitize_params: true,
) || return
@agents = @filterrific.find.paginate(page: params[:page], per_page: 10)
end
index.html.erb
<%= form_for_filterrific @filterrific do |f| %>
<div>
Search
<%= f.text_field(
:search_query,
class: 'filterrific-periodically-observed'
) %>
</div>
<div>
Sorted by
<%= f.select(:sorted_by, @filterrific.select_options[:sorted_by]) %>
</div>
<div>
<%= link_to(
'Reset filters',
reset_filterrific_url,
) %>
</div>
<%# add an automated spinner to your form when the list is refreshed %>
<%= render_filterrific_spinner %>
<% end %>
<%= render(
partial: 'agents/list',
locals: { agents: @agents }
) %>
_list.html.erb (partial)
<div id="filterrific_results">
<table class="table">
<thead>
<tr>
<th><%= filterrific_sorting_link(@filterrific, :name) %></th>
<th><%= filterrific_sorting_link(@filterrific, :location) %></th>
</tr>
</thead>
<tbody>
<% agents.each do |agent| %>
<tr>
<td><%= agent.name %></td>
<td><%= agent.location %></td>
</tr>
<% end %>
</tbody>
</table>
</div>
<%= will_paginate agents %>
logs
Started GET "/agents?filterrific%5Bsorted_by%5D=location_desc" for ::1 at 2020-03-12 16:26:07 +0530
Processing by AgentsController#index as JS
Parameters: {"filterrific"=>{"sorted_by"=>"location_desc"}}
User Load (301.8ms) SELECT "users".* FROM "users" WHERE "users"."id" = $1 ORDER BY "users"."id" ASC LIMIT $2 [["id", 5], ["LIMIT", 1]]
↳ app/controllers/agents_controller.rb:107:in `authenticate_user'
Rendering agents/index.js.erb
Agent Load (248.2ms) SELECT "agents".* FROM "agents" ORDER BY location desc LIMIT $1 OFFSET $2 [["LIMIT", 10], ["OFFSET", 0]]
↳ app/views/agents/_list.html.erb:20
Rendered agents/_list.html.erb (Duration: 255.6ms | Allocations: 1562)
Rendered agents/index.js.erb (Duration: 268.5ms | Allocations: 5750)
Completed 200 OK in 585ms (Views: 27.3ms | ActiveRecord: 550.0ms | Allocations: 8947)
I think you need to add some javascript in order to live update your result. Can you add the following code as index.js.erb
along side with index.html.erb
<% js = escape_javascript(
render(partial: agents/list, locals: { agents: @agents })
) %>
$("#filterrific_results").html("<%= js %>");