Установить значение в контроллере, используя вложенный ресурс - PullRequest
0 голосов
/ 12 апреля 2010

У меня есть две модели, продукт и заказ.

Product
 - cost
 - id

Order
 - cost
 - product_id

Каждый раз, когда кто-то размещает заказ, он фиксирует product_id через значение переключателя в форме «новый заказ».

В контроллере при создании нового заказа ему нужно установить order.cost на order.product.cost. Логически я думал, что код должен быть примерно таким:

def create
...
   @order.cost == @order.product.cost
...
end

Однако я не могу заставить его работать вообще, поэтому я задаю вопрос здесь.

Любая помощь - ответ (или наименование) вопроса будет принята с благодарностью.

Ответы [ 2 ]

0 голосов
/ 12 апреля 2010

Другой вариант - указать before_create для модели Order, но это сработает, только если КАЖДЫЙ Заказ должен быть создан таким образом.

class Order < ActiveRecord::Base
  has_many :products 
    #this could be has_one if you really want only one product per order
  accepts_nested_attributes_for :products
    #so that you can do Order.new(params[:order])
    #where params[:order] => [{:attributes_for_product => {:id => ...}}] 
    #which is handled by fields_for in the view layer.

    #has_one would make this :product

  before_create :calculate_order_cost_from_product 
    #only run on the first #save call or on #create

  def calculate_order_cost_from_product
      self.cost = self.products.first.cost 
       #this could also be self.products.sum(&:cost) 
       #if you wanted the total cost of all the products

       #has_one would be as you had it before:
       #self.cost = self.product.cost
  end

end
0 голосов
/ 12 апреля 2010

Неправильный синтаксис

@order.cost == @order.product.cost #it will compare the product cost & order cost & return boolean value true ot false

Его должно быть

@order.cost = @order.product.cost

Если вы правильно пишете ассоциации в модели, это должно быть следующим образом

product.rb

has_many :orders

order.rb

belongs_to :product
...