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

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了具有连接表关系的活动管理员相关的知识,希望对你有一定的参考价值。

我正在配置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] }

但是当我尝试写它们时它不起作用。编辑值也不起作用。

我在哪里错过了什么?我怎样才能使这个工作?

**** ****更新

经过一番工作,我得到了以下解决方案:

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

使用这两种解决方案,我能够编写一个新的杂志条目并将关联写入连接表,不幸的是它在表单中显示#<Keyword:0x10c858858>而不是单词。我错过了什么?

答案

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

以上是关于具有连接表关系的活动管理员的主要内容,如果未能解决你的问题,请参考以下文章

具有相同功能的活动和片段

代码第一个约定不在实体框架6.2中的多对多关系上创建连接表

开发具有多个活动或一个活动和多个片段的应用程序?

具有多个片段的活动的 MVP

Laravel 连接 3 个表

Android 片段和活动