collection_selectの選択肢から特定の値を省く
やりたいこと
form_withを使用してフォームを作成、
collection_selectでモデルAの中身を選択肢として提示、
値をモデルBに保存。
提示する際、モデルBにすでに保存されている項目を選択肢から除外する。
モデル情報
モデルA = Category_list(ActiveHashを使用)
self.data = [
{ id: 1, name: '〇〇' }....
]
モデルB = Category
name: integer(モデルAのidを保存)
user: references
調べたこと
条件を指定してモデルから値を取得する方法
- モデル.find()
- モデル.where()
- モデル.where.not()
1番・2番
指定したものに該当するレコードを取得するもの。
今回は指定したものに該当しないレコードを取得したいので、除外。
3番
指定したものに該当しないレコードを取得するもの。
ただ、複数条件を指定するためには配列を使用する必要がある。
モデルA.where.not(id: [1,2,3])
categories = モデルB.where(user_id: current_user.id)
モデルA.where.not(id: categories.name)
だと取得できない...
解決策
コントローラーでモデルBのnameカラムの値を配列に入れる、
その配列を使用してモデルAから取得する
categories = モデルB.where(user_id: current_user.id)
category_ids = add_category_ids(categories)
モデルA.where.not(id: category_ids)
def add_category_ids(categories)
category_ids = []
nategories.each do |category|
category_id = category.name
category_ids << category_id.to_i
end
return category_ids
end
無理矢理すぎるかな...?