0

模型

class Rfq < ActiveRecord::Base   
  belongs_to :purchase
  belongs_to :supplier
  belongs_to :customtemplate
end

class Purchase < ActiveRecord::Base 
  belongs_to :order

  #Products
  has_many :purchase_products, dependent: :destroy 
  has_many :products, through: :purchase_products
  accepts_nested_attributes_for :purchase_products, allow_destroy: true 

  validates :code, uniqueness: true
  validates :code, presence: true

  validates :order_id, presence: true  
end

class Supplier < ActiveRecord::Base
  has_many :products, dependent: :destroy
  accepts_nested_attributes_for :products, allow_destroy: true

  validates :code, uniqueness: true
  validates :code, presence: true
end


class Customtemplate < ActiveRecord::Base
    has_many :supplier_templates, dependent: :destroy, :foreign_key => 'customtemplate_id'
   has_many :suppliers, through: :supplier_templates 

   validates :code, uniqueness: true
  validates :code, :body, presence: true
end

rfqs_controller

class RfqsController < ApplicationController
(..)
def new
    @rfq = Rfq.new
    #@purchase_products = PurchaseProduct.where(purchase_id: params[:purchase_id])

    #RFQ for one purchase
    if params[:purchase_id].present?
      @a_products_suppliers = []

      products = Purchase.find(params[:purchase_id]).products
      @suppliers = products.select(:supplier_id).uniq

      products.each do |p|
        @a_products_suppliers.push(p.supplier_id => p.id)
        #binding.pry
      end
    end
    binding.pry

  end
(..)

模型字段之一是定义为数组类型的“产品”。

从控制器,在@a_products_suppliers 我收到散列数组 [{supplier_id=>product_id}]

(#<RfqsController>)> @a_products_suppliers
=> [{9=>5}, {9=>4}]

形式

<% @suppliers.each do |s| %>

  <%= simple_form_for @rfq do |f| %>
      <%= f.error_notification %>

      <h3>Products</h3>

      <% @a_products_suppliers.each do |a| %>
        <%= f.collection_check_boxes a[s.supplier_id] ???
      <% end %>

      <%= f.button :submit %>

  <% end %>
<% end %>

我不知道如何列出每个产品,允许用户使用复选框来定义哪些产品应该存储在表 rfqs 的“产品”列中。

标签可以通过以下方式获得:Product.find(a[s.supplier_id]).code

某人可以帮我吗?

4

1 回答 1

0

请尝试以下方法:

<%= collection_check_boxes(:student, :subject_ids, Student.order('name'), :id, :name) do |b| %>
   <%= b.check_box %>
   <%= b.label %>
<% end %>

我在哪里有学生 - 主题多对多关系。collection_check_box 自身迭代。

如果您遇到任何问题,请告诉我...

于 2016-08-10T11:38:02.487 回答