具有连接表关系的活动管理员

时间:2018-03-02 11:34:12

标签: mysql ruby-on-rails ruby-on-rails-3 activerecord activeadmin

我正在配置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>而不是单词。我错过了什么?

1 个答案:

答案 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