前提・実現したいこと
3つの検索条件(ジャンル・地域・タグ)からレストランを検索できるアプリケーションを作っています。
ジャンル・地域はshopテーブルのカラムとして保存しています。
タグは、
shopテーブルーshop_tag_relation中間テーブルーtagテーブル
のように中間テーブルを用いて保存しています。
発生している問題・エラーメッセージ
NoMethodError in ShopsController#search undefined method `to_i' for ["", "1"]:Array
条件を入力し、submitボタンを押すと上記エラーが発生してしまいます。
該当のソースコード
検索フォーム
genreとprefectureは一致したものを検索したいのでヘルパーメソッド_eqを使用
タグは指定した値が含まれているもの全てを検索したいのでヘルパーメソッド_contを使用
ruby
1#index.html.erb 2 <%= search_form_for @p, url: shops_search_path do |f| %> 3 <div class="form form-genre"> 4 <%= f.label :genre_eq, 'ジャンル' %> 5 <%= f.collection_select :genre_id_eq, Genre.all, :id, :name, include_blank: '指定なし' %> 6 <br> 7 </div> 8 9 <div class="form form-address"> 10 <%= f.label :prefecture_eq, '所在地' %> 11 <%= f.collection_select :prefecture_id_eq, Prefecture.all, :id, :name, include_blank: '指定なし' %> 12 <br> 13 </div> 14 <div class="form form-tag"> 15 <div class="col-md-4 radio-buttons-list"> 16 <%= f.label :shop_tag_relations_tag_id_cont, 'こだわり条件' %> 17 <%= f.collection_check_boxes :shop_tag_relations_tag_id_cont, Tag.all, :id, :name %> 18 <br> 19 </div> 20 </div> 21 <%= f.submit '検索' %> 22 <% end %>
コントローラー
ストロングパラメーターは一時的になんでも通るように設定しています。
ruby
1class ShopsController < ApplicationController 2 ~~ 3 before_action :search_shop, only: [:index, :search] 4 def index 5 @shops = Shop.all.order("created_at DESC") 6 set_shop_column 7 set_tag_column 8 end 9 10~~ 11 def search 12 @results = @p.result.includes(search_params) 13 end 14 15 private 16 ~~ 17 def search_shop 18 @p = Shop.ransack(params[:q]) #検索を指示 19 end 20 21 def search_params 22 params.require(:q).permit! 23 end 24 def set_shop_column 25 @shop_genre = Shop.select("genre_id").distinct 26 @shop_prefecture = Shop.select("prefecture_id").distinct 27 end 28 def set_tag_column 29 @shop_tags = ShopTagRelation.select("tag_id").distinct 30 end 31 32end 33
試したこと
検索フォームで配列でパラメーターを送信するために:shop_tag_relations_tag_ids_contにするなど試しましたがダメでした...。
丸1日ハマり続けています。
是非とも、お力添えよろしくお願いいたします。
補足情報(FW/ツールのバージョンなど)
docker環境
rails6
ruby2.6.5
mysql2
ここにより詳細な情報を記載してください。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2021/01/05 12:59