我正在配置Active Admin。一切都在连接表中运行,连接表将杂志资源与关键字资源相连接。一个杂志由多个关键字定义,关键字可以定义多个杂志。
我有两种模式:
### models/magazine.rb
class Magazine < ActiveRecord::Base
attr_accessible :colour, :cover_alt, :description, :number, :short, :title_id
has_and_belongs_to_many :keywords, :join_table => "magazines_keywords"
belongs_to :title, :class_name => "Keyword", :foreign_key => "title_id"
end
### models/keywords.rb
class Keyword < ActiveRecord::Base
attr_accessible :word, :description
has_and_belongs_to_many :magazines, :join_table => "magazines_keywords"
end
和一个联接表:
### models/magazines_keyword.rb
class MagazinesKeyword < ActiveRecord::Base
attr_accessible :magazine_id, :keyword_id
belongs_to :magazine
belongs_to :keyword
end
这个设置适用于我的rails应用程序的视图,我有我的AA杂志资源的索引和显示部分工作,但表单(新的和编辑)不起作用:
ActiveAdmin.register Magazine do
menu :priority => 1
form do |f|
f.semantic_errors *f.object.errors.keys
f.inputs "Magazine Details" do
f.input :title_id, :label => 'Title', :as => :select, :collection => Keyword.all.map{ |u| ["#{u.word.capitalize}", u.id] }
f.inputs :magazines_keywords do
f.has_many : magazines_keywords do |s|
s.input :keyword, :as => :select, :multiple => true, :collection => MagazinesKeyword.all.map { |u| ["#{u.keyword.word.capitalize}", u.id] }
end
end
end
f.actions
end
show do
panel "Magazine Details" do
attributes_table_for magazine do
row "Keywords", :keyword do |m|
m.keywords.map { |d| d.word }.join(", ").html_safe
end
end
end
active_admin_comments
end
end
运行应用时,我会NoMethodError in Admin/magazines#edit
/active_admin/resource/edit.html.arb line #1
提升undefined method 'klass' for nil:NilClass
我可以在表单部分显示所有关键字:
f.input :magazines_keywords, :as => :check_boxes, :multiple => true, :collection => MagazinesKeyword.all.map{ |u| ["#{u.keyword.word.capitalize}", u.id] }
但是当我尝试写它们时它不起作用。编辑值也不起作用。
我在哪里错过了什么?我怎样才能使这个工作?
**** **** UPDATE
经过一番工作后,我得到了以下解决方案:
form do |f|
f.semantic_errors *f.object.errors.keys
f.inputs "Saft Details" do
f.input :title_id, :label => 'Title', :as => :select, :collection => Keyword.all.map{ |u| ["#{u.word.capitalize}", u.id] }
f.input :keywords, :as => :check_boxes, :input_html => {:multiple => true}
end
f.actions
end
并按照建议:
f.input :keywords, :as => :check_boxes, :input_html => {:multiple => true} do
f.has_many :keywords do |s|
s.input :keyword, :collection => Keyword.all.map { |kw| ["#{kw.word.capitalize}", kw.id] }
end
end
使用这两种解决方案,我可以编写一个新的Magazine条目并将关联写入连接表,不幸的是它在表单中显示#<Keyword:0x10c858858>
而不是单词。我错过了什么?
答案 0 :(得分:0)
ActiveAdmin非常聪明地了解您要执行的操作。因此,您应该忽略MagazinesKeyword
并直接转到Keyword
模型。
所以你应该改变这个:
f.has_many :magazines_keywords do |s|
s.input :keyword, :as => :select, :multiple => true, :collection => MagazinesKeyword.all.map { |u| ["#{u.keyword.word.capitalize}", u.id] }
end
用这个:
f.has_many :keywords do |s|
s.input :keyword, :as => :select, :multiple => true, :collection => Keyword.all.map { |kw| ["#{kw.word.capitalize}", kw.id] }
end
主动管理员将自行处理MagazinesKeyword
。