Как создать функцию поиска диапазона для созданного - PullRequest
0 голосов
/ 25 марта 2020

Я хочу создать функцию поиска по диапазону для "creation_at" (между созданным_т_ и созданным_т_). Но эта функция реализует только созданные Как я могу создать функцию поиска для диапазона дат?

вот мой код: paper.rb

scope :search, -> (search_params) do
  return if search_params.blank?

  box_name(search_params[:box])
  .created_at_from(search_params[:created_at_from])
  .created_at_to(search_params[:created_at_to])
end
scope :box_name, -> (box) { where('box LIKE ?', "%#{box}%") if box.present? }
scope :created_at_from, -> (from) { where('? <= created_at', from) if from.present? }
scope :created_at_to, -> (to) { where('? <= created_at', to) if to.present? }

apers_controller.rb

def index
@search_params = papaer_search_params
@papers = Paper.search(@search_params).order(created_at: "DESC")
end
.
.
.
def paper_search_params
 params.fetch(:search, {}).permit(:box, :created_at_from, :created_at_to)
end

index. html .erb

<%= form_with(scope: :search, url: index_papers_path, method: :get, local: true) do |f| %>
<%= f.label :box, "Box" %>
<%= f.text_field :box, value: @search_params[:box], class: 'form-control' %>

<span id='date-form' class='input-custom'>
  <%= f.label :created_at, t('views.payment.date_from').html_safe + ':' %>
  <%= f.text_field :created_at_from, {value: @search_params[:created_at_from], :class => 'form-control datepicker', :required => false} %> ~
<%= f.text_field :created_at_to, {value: @search_params[:created_at_to], :class => 'form-control datepicker', :required => false} %>

<%= submit_tag 'Search', class: "button" %>

1 Ответ

0 голосов
/ 25 марта 2020

Ваши запросы from и to равны, поэтому один из них не работает должным образом. Просто измените их на:

scope :created_at_from, -> (from) { where('created_at <= ?', from) if from.present? }
scope :created_at_to,   -> (to)   { where('? <= created_at', to  ) if to.present?   }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...