Я пытаюсь добавить отношение has_many_through через форму, вложенную в родительскую модель. Я не могу понять, возможно ли это?
Вложенная форма работает нормально без флажков. И флажки работают нормально, когда они находятся за пределами вложенной формы.
= semantic_form_for @raduser do |f|
%ul
%li
= f.text_field :expiration, :placeholder => 'Expiration Date', :id => 'expiration_date'
- f.fields_for :radcheck do |builder|
= builder.text_field :username, :placeholder => 'Stuff'
-Radgroup.all.each do |group|
%li
= check_box_tag 'radcheck[radgroup_ids]', group.id, @radcheck.radgroup_ids.include?(group.id)
= group.groupname
%li
= f.submit
Это выдает ошибку:
undefined method `radgroup_ids' for #<ActiveRecord::Relation:0x007faaa24c2468>
Мне кажется, что все модели настроены нормально, поскольку все значения сохраняются без флажков
--- РЕДАКТИРОВАТЬ ДОБАВЛЕННЫЕ МОДЕЛИ ---
У Radusers есть много Radcheck (единственное число из-за устаревшего db). Radcheck имеет много радгрупп через radusergroup.
class Raduser < ActiveRecord::Base
has_many :radcheck, :dependent => :destroy
accepts_nested_attributes_for :radcheck, :reject_if => lambda { |a| a[:value].blank? }, :allow_destroy => true
end
class Radcheck < ActiveRecord::Base
self.table_name = 'radcheck'
attr_accessible :attribute_name, :username, :value, :op, :radgroupcheck_id, :radcheck_serial, :radgroup_ids
belongs_to :raduser
has_many :radusergroup, :dependent => :destroy
has_many :radgroup, :through => :radusergroup
end
class Radgroup < ActiveRecord::Base
self.table_name = 'radgroup'
has_many :radusergroup, :dependent => :destroy
has_many :radcheck, :through => :radusergroup
end
class Radusergroup < ActiveRecord::Base
belongs_to :radcheck
belongs_to :radgroup
end
- ОБНОВЛЕНИЕ ВТОРОЕ -
def new
@radcheck = Radcheck.new
...
end
def create
@radcheck = Radcheck.new(params[:radcheck])
...
end
--- ОБНОВЛЕНИЕ 3 ---
Мой БД в настоящее время выглядит так:
+----------------+-----------------------+----------+------+
| radcheck_id | radgroup_id | priority | id |
+----------------+-----------------------+----------+------+
| 8 | 3 | 1 | 1 |
| 4 | 9 | 0 | 2 |
| 22 | 4 | 1 | 3 |
| 2 | 6 | 1 | 4 |
У меня есть предложенное ниже решение, работающее.
То, что я надеялся сделать, это вставить в базу данных radcheck_username и radgroup_groupname, а не radcheck_id:
+----------------+-----------------------+----------+------+
| ...username | --groupname | priority | id |
+----------------+-----------------------+----------+------+
| user123344 | group88888 | 1 | 1 |
| shushQb | 30-minutes | 0 | 2 |
| forty | gigiig | 1 | 3 |
| snang | ps-staff | 1 | 4 |
Возможно ли это?