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

 

調べたこと

条件を指定してモデルから値を取得する方法

  1. モデル.find()
  2. モデル.where()
  3. モデル.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

無理矢理すぎるかな...?