1

我的目标是为用户和特定项目的每个关系显示选择框。需要列出所有用户,但只有项目用户具有某种类型的关系。其他用户在他们的选择框中没有选择。

我有这个模型:

class Project < ActiveRecord::Base
    belongs_to :company
    has_many :tasks, :order => 'state_type_id ASC'

    has_many :project_user_relations
    has_many :users, :through => :project_user_relations

    def t_name
       name.camelcase
    end
end

class User < ActiveRecord::Base
    belongs_to :company

    has_many :tasks , :foreign_key => :assigned_user_id 

    has_many :project_user_relations
    has_many :projects, :through => :project_user_relations

    def full_name
     firstname + ' ' + lastname
    end

    def relation_to(project)
     relation=ProjectUserRelation.find_by_project_id_and_user_id(project.id, id)
     relation ||= relation=ProjectUserRelation.new
    end
end

class ProjectUserRelation < ActiveRecord::Base
    belongs_to :project
    belongs_to :user
    has_one :project_user_relation_type
end

class ProjectUserRelationType < ActiveRecord::Base
    def t_name
        I18n.t("app.projects.users.relation.type."+code)
    end
end

我想用collection_select制作一个表格来显示所有用户。我使用了代码:

def edit_all
   @project = Project.find(params[:project_id])
   @users = User.all
....

在我的控制器 路线中工作正常。

在我看来:

<% @users.each do |user| %>
   <%= f.fields_for :users, user do |user_fields| %>
     <tr class="reference" rel="<%=  parent_user_path(user)  %>" >
        <td class="name"><%= link_to user.full_name, parent_user_path(user) %></td>
        <td class="email"><%= mail_to user.email %></td>
        <td class="type">
            <%= user_fields.fields_for user.relation_to @project do |relation_fields| %>
                <%= relation_fields.collection_select :project_user_relation_type, ProjectUserRelationType.all, :id, :t_name, {:include_blank => false, :prompt => t("helpers.select.prompt") } %>
            <%  end %>
         </td>
      </tr>
   <% end %>      
<% end %>     

或用于测试:

<%= f.fields_for :users, @users do |xuser_fields| %>
    <% logger.debug "#{self.to_s} xuser_fields = #{xuser_fields.object.inspect} ;" %>
    <tr>
       <td><%= xuser_fields.text_field :firstname %></td>
       <td></td>
       <td></td>
       <td></td>
    </tr>
<% end %>

但炒锅不正确

第一个在 html 中生成错误的名称:

选择 id="project_users_project_user_relation_project_user_relation_type" name="project[users][project_user_relation][project_user_relation_type]"

第二个生成错误:# Array:0x4d03658 的未定义方法 `firstname'

你能帮我解决这种情况吗?

PS:对不起长代码:(


解决方案(可能 - 通过阅读 RoR 资源解决)

我找到了解决方案。

一个方法

def name_attributes=(attributes)
    # Process the attributes hash
end

项目模型中的缺失。

这是令人难以置信的解决方案:]。在 fields_for: :name, @some_collection 之后还有精确的语法,其中name必须与 Model 中提到的 def 开头的名称完全相同。

4

0 回答 0