7

こんにちは、私はランサック + kalendae_assets gem を使用して、開始日と終了日の間でレコードを検索してい ます。

ここに私のコードがあります

<%= search_form_for @search, url: guest_search_rooms_path, html: {:method =>:post} do |f| %>
  <%= f.label :start_date_eq , "Start Date"%>   
  <%= f.text_field :start_date_eq, class: 'release_date' %>     

  <%=f.label :end_date_eq, "End Date" %>   
  <%= f.text_field :end_date_lteq, class: 'release_date' %>     
  <%= f.submit "search" %>
<% end %>

部屋.コントローラー

def guest_search 

  @search = Room.search(params[:q])
  @roome = @search.result(:distinct => true)
  @room= @roome.where("status IS ?", true).order("room_type_id desc")

  #@room = @search.result(:distinct => true)
 end 

しかし、開始日と終了日を入力すると、これを行う方法が検索されません

4

6 に答える 6

7

https://github.com/dangrossman/bootstrap-daterangepickerを使用すると、次の日付範囲検索を実行できます。

= search_form_for q, url: orders_path, builder: SimpleForm::FormBuilder do |f|
  = f.input :daterange , input_html: {value: "#{q.date_gteq.to_s} - #{q.date_lteq.to_s}"}
  = f.input :date_gteq, as: :hidden
  = f.input :date_lteq, as: :hidden

:coffee
  $ ->
    $('#q_daterange').daterangepicker
      format: "YYYY-MM-DD"
      startDate: $('#q_date_gteq').val()
      endDate: $('#q_date_lteq').val()
      ranges:
        'This Week': [moment().startOf('week'), moment().endOf('week')],
        'Next Week': [moment().add('week', 1).startOf('week'), moment().add('week', 1).endOf('week')]
    , (start, end, label) ->
      $('#q_date_gteq').val start.format("YYYY-MM-DD")
      $('#q_date_lteq').val end.format("YYYY-MM-DD")
    .on 'apply.daterangepicker', -> $('#order_search').submit()
于 2014-06-27T21:22:01.150 に答える
4

カスタム述語を作成できます。

私の見解では、次のようなランサック検索フィールドがあります

= f.text_field :request_date_between, class: 'daterange'

それは次のようにコントローラーに日付を送信します

「2015-10-01 から 2015-10-31」

次に、ダウンしてダーティーな ransack.rb イニシャライザに入れました。

Ransack.configure do |config|
  config.add_predicate 'between',
                       arel_predicate: 'between',
                       formatter: proc { |v| v.split(' to ') },
                       type: :string
end

module Arel
  module Predications
    def between other
      gteq(other[0]).and(lt(other[1]))
    end
  end
end
于 2016-08-29T14:48:39.797 に答える
2

開始日と終了日で範囲を使用できます。その後、日付間の検索結果を取得できます。検索フォームのサンプル コードは次のとおりです。

<div class="control-group">
    <%= f.label :scrap_date_cont, "Scrap Date", class: 'control-label' %>
    <div class="controls">
      <% if q.scrap_date_cont.blank? %>
    <%= f.text_field :scrap_date_cont, include_blank: true, default: nil, :class => 'datepicker3', :style=>"width:100px;" %> 
      <% elsif !q.scrap_date_cont.blank? %>
      <%= f.text_field :scrap_date_cont, :value => "#{change_date_format_for_edit_page(q.scrap_date_cont)}", :class => 'datepicker3', :style=>"width:100px;" %> 
      <% end %>&nbsp;<%= link_to "Select Range", "#", :id => 'dates' %> 

    </div>
  </div>


     <div class="control-group" id="range" style="display:none" >
        <%= f.label :scrap_date_gteq, "Range", class: 'control-label' %>

        <div class="controls">
          <% if q.scrap_date_gteq.blank? %>
          <%= f.text_field :scrap_date_gteq, include_blank: true, default: nil, :class => 'datepicker1', :style=>"width:100px;" %>
          <% elsif !q.scrap_date_gteq.blank? %>
          <%= f.text_field :scrap_date_gteq, :value => "#{change_date_format_for_edit_page(q.scrap_date_gteq)}", :class => 'datepicker1', :style=>"width:100px;" %> 
          <% end %>

           <% if q.scrap_date_lteq.blank? %>
          <%= f.text_field :scrap_date_lteq, include_blank: true, default: nil, :class => 'datepicker2', :style=>"width:100px;"  %>
           <% elsif !q.scrap_date_lteq.blank? %>
           <%= f.text_field :scrap_date_lteq, :value => "#{change_date_format_for_edit_page(q.scrap_date_lteq)}", :class => 'datepicker2', :style=>"width:100px;" %> 
           <% end %>
        </div>
      </div>

そして、ここにコントローラーコードがあります:

params[:q][:scrap_date_cont] = change_date_format(params[:q][:scrap_date_cont]) if !(params[:q][:scrap_date_cont]).blank?
    params[:q][:scrap_date_cont] =  params[:q][:scrap_date_cont].to_date.strftime("%d/%Y/%m") if !(params[:q][:scrap_date_cont]).blank?
    params[:q][:scrap_date_gteq] = change_date_format(params[:q][:scrap_date_gteq]) if !(params[:q][:scrap_date_gteq]).blank?
    params[:q][:scrap_date_gteq] =  params[:q][:scrap_date_gteq].to_date.strftime("%d/%Y/%m") if !(params[:q][:scrap_date_gteq]).blank?
       params[:q][:scrap_date_lteq] = change_date_format(params[:q][:scrap_date_lteq]) if !(params[:q][:scrap_date_lteq]).blank?
     params[:q][:scrap_date_lteq] =  params[:q][:scrap_date_lteq].to_date.strftime("%d/%Y/%m") if !(params[:q][:scrap_date_lteq]).blank? 

ヘルパー コード:

#Change date format in edit time
 def change_date_format_for_edit_page(date)
    new_date = date.strftime("%m/%d/%Y")
    puts new_date.inspect
    return new_date
  end

脚本 :

$("#dates").click(function () {
  var $that = $(this);
  $("#range").toggle("slow", function() {
    $that.toggleClass("toggled-off");
  });
});

私はそれがあなたを助けるかもしれないと思う...

于 2014-03-13T07:34:11.630 に答える