Given Problem
& Observer
model:
class Problem < ActiveRecord::Base
has_many :observers
accepts_nested_attributes_for :observers
end
class Observer < ActiveRecord::Base
belongs_to :problem
belongs_to :user
end
I am trying to use form_for
to select users as observers:
<%= f.fields_for :observers do |obs| %>
<%= obs.collection_select(:user_id, Users.to_a, :id, :name, {:include_blank => true, include_hidden: false}, {:multiple => true}) %>
<% end %>
However Rails generates wrong name for select: problem[observers_attributes][0][user_id][]
, so even creating a rule for strong_params ({:observers_attributes => [{:user_id => []}]}
) it creates wrong relationship, only problem_id goes to the database, and all user_id are being ignored.
What I'm trying to do is to show all users in multiple select, grab IDs and create association for them in Problem#new
method.
UPDATE 12.10
Posted Parameters:
Parameters: {"utf8"=>"✓", "authenticity_token"=>"NHDl/hrrFgATQOoz9A3OLbLDAbTMziKMQW9X1y2E8Ek=", "problem"=>{"problem_data_attributes"=>{"title"=>"safasfasfafsasf", "description"=>""}, "observers_attributes"=>{"0"=>{"user_id"=>["5", "8"]}}}}
Strong Params:
def problem_params
params.require(:problem).permit({:files_attributes => [:attach_id]}, {:observers_attributes => {:user_id => []}}, {:problem_data_attributes => [:title, :description]})
end
Create method
def create
@problem = @project.problem.build(problem_params)
@problem.account = current_account
if @problem.save
render :json => {status: true, id: @problem.id}
else
respond_with(@problem)
end
end
And SQL that creates observer during create call:
SQL (0.2ms) INSERT INTO `observers` (`problem_id`) VALUES (96)