2

我与Formtastic面临的问题属性是,我有一个表格,以创建一个新的Order。在这种形式下,我想从列表中选择多个现有的Food项目。这些应该被添加到我提交的新订单中。同时我也想在FoodOrder连接模型中设置属性。此模型具有整数数量属性,我希望在该表单中有一个字段。Rails的Formtastic嵌套形式 - 形式从加盟模式

什么我基本上找的是,列出了所有食品和在同一行,因为它属于食品项目把一个场为quantity一种形式。

模型

class Order < ActiveRecord::Base 
    belongs_to :user 
    belongs_to :restaurant 
    has_many :food_orders 
    has_many :foods, :through => :food_orders 
end 

class FoodOrder < ActiveRecord::Base 
    belongs_to :food 
    belongs_to :order 
end 

class Food < ActiveRecord::Base 
    has_many :food_orders 
    has_many :orders, :through => :food_orders 
    belongs_to :category 
end 

这是迄今为止我已经试过形式的版本之一。但我只是感到困惑,不知道如何为FoodOrder模型获取字段。

<%= semantic_form_for [@restaurant, @order] do |f| %> 
    <%= f.inputs do %> 
    <%= f.input :comment %><br /> 
    <%= f.input :table_id %><br /> 
    <%# <%= f.input :foods, :as => :check_boxes %> 
    <%= f.inputs :for => :foods do |food| %> 
     <%= food %> 
     <%= food.inputs :quantity %> 
    <% end %> 
    <% end %> 
    <%= f.buttons do %> 
    <%= f.commit_button %> 
    <% end %> 
<% end %> 

我的模型具有这些属性

create_table "food_orders", :force => true do |t| 
    t.integer "quantity", :null => false 
    t.decimal "price",  :null => false 
    t.integer "food_id", :null => false 
    t.integer "order_id", :null => false 
    t.text  "comment" 
    t.datetime "created_at", :null => false 
    t.datetime "updated_at", :null => false 
end 

create_table "foods", :force => true do |t| 
    t.integer "category_id",      :null => false 
    t.string "name",       :null => false 
    t.string "description" 
    t.string "image" 
    t.decimal "default_price",     :null => false 
    t.boolean "active",  :default => true, :null => false 
    t.datetime "created_at",      :null => false 
    t.datetime "updated_at",      :null => false 
end 

create_table "orders", :force => true do |t| 
    t.integer "restaurant_id",     :null => false 
    t.integer "user_id",       :null => false 
    t.integer "table_id",       :null => false 
    t.decimal "total",       :null => false 
    t.datetime "finished_at" 
    t.datetime "created_at",      :null => false 
    t.datetime "updated_at",      :null => false 
end 

回答

0

基本上我最终会做的是创造每一个Food对象FoodOrder则仅保存有大于0

值的那些你可以这样做,在一个reject_ifaccepts_nested_attributes_for但不会删除旧FoodOrder s表示有人可能会改变从3比0。因此,你将不得不重写ŧ他的quantity=方法FoodOrder

我从来没有使用formtastic之前,但我会采取一种猜测,并说,这应该工作。

<%= semantic_form_for [@restaurant, @order] do |f| %> 
    <%= f.inputs do %> 
    <%= f.input :comment %><br /> 
    <%= f.input :table_id %><br /> 
    <% @foods.each do |food| 
     <%= f.semantic_fields_for :food_orders, 
          @order.food_orders.detect_or_build_by_food(food) 
          do |food_order| %> 
     <%= food %> 
     <%= food_order.inputs :quantity %> 
     <% end %> 
    <% end %> 
    <% end %> 
    <%= f.buttons do %> 
    <%= f.commit_button %> 
    <% end %> 
<% end %> 

order.rb:

class Order < ActiveRecord::Base 
    belongs_to :user 
    belongs_to :restaurant 
    has_many :foods, :through => :food_orders 
    has_many :food_orders do 
    def detect_or_build_by_food(food) 
     record = self.detect{ |food_order| food_order.food_id == food.id } 
     if record.nil? 
     record = self.build(:food => food) 
     end 
     record 
    end 
    end 

    accepts_nested_attributes_for :food_orders 
end 

food_order.rb:

class FoodOrder < ActiveRecord::Base 
    belongs_to :food 
    belongs_to :order 

    def quantity=(quantity) 
    if quantity <= 0 
     self.destroy 
    else 
     self[:quantity] = quantity 
    end 
    end 
end 

我希望的作品,但它是未经测试的代码,所以是...祝你好运!

+0

谢谢您的回答!表格现在看起来不错,就像我在找的那样。不幸的是,我得到'不能修改冻结哈希'Rails运行时错误。不允许修改'FoodOrder'中的数量吗?任何想法可能来自哪里? – patrickdet 2012-01-08 11:32:17

+0

嗯,它可能是在我要成为我的电话了一天休息的方法摧毁,但你可以试试“mark_for_destruction”代替。但是,如果这样做不起作用,那就完全消灭这个破坏,看看会发生什么。 – Azolo 2012-01-08 11:50:40

+0

感谢您的快速回复。 '.mark_for_destruction'也没有评论它的工作。都导致'SQLite3 :: ConstraintException:约束失败:INSERT INTO“food_orders”' – patrickdet 2012-01-08 12:05:32