简单地说,一个联系人可以有各种关联的时间窗口,这些时间窗口可能会或可能不会作为计划活动。以机智:
楷模
class Contact < ActiveRecord::Base
has_many :schedules
has_many :time_windows, :through => :schedules
accepts_nested_attributes_for :schedules, :allow_destroy => true
end
class TimeWindow < ActiveRecord::Base
has_many :schedules
has_many :contacts, :through => :schedules
end
class Schedule < ActiveRecord::Base
belongs_to :contact
belongs_to :time_window
end
看法
<% TimeWindow.all.each do |tw| %>
<% schedule = Schedule.find_by_contact_id_and_time_window_id(@contact.id, tw.id)
schedule ||= Schedule.new %>
<p>
<%= f.label tw.description %>
<%= hidden_field_tag "contact[schedules_attributes][][id]", schedule.id %>
<%= check_box_tag "contact[schedules_attributes][][time_window_id]",
tw.id, @contact.time_windows.include?(tw) %>
<%= check_box_tag "contact[schedules_attributes][][active]", nil,
schedule.active %>
</p>
<% end %>
这会提交如下内容:
Parameters: { "commit" => "Update", "contact" => {
"group_ids" => ["2"], "enabled" => "1",
"schedules_attributes" => [ { "time_window_id"=>"1", "id"=>"46"},
{ "time_window_id" => "2", "id" => "42", "active" => "on" },
{ "time_window_id" => "3", "id" => "43"},
{ "time_window_id" => "4", "id" => "44", "active" => "on"}],
"last_name" => ...
控制器中的更新操作基本上是库存,除了处理另一个相关模型的另一个实例,我使用 Advanced Rails 食谱书中的“处理多个模型”示例进行编码。
根据this API doc,我认为上面应该可以工作。但是,有关时间表的任何内容都没有更新。这显示在服务器日志中:
[4;35;1mSchedule Update (0.2ms)[0m [0mUPDATE `schedules` SET `updated_at` = '2010-09-30 20:39:49', `active` = 0 WHERE `id` = 42[0m
[4;36;1mSchedule Update (0.1ms)[0m [0;1mUPDATE `schedules` SET `updated_at` = '2010-09-30 20:39:49', `active` = 0 WHERE `id` = 44[0m
(NetBeans 在输出中给了我那些愚蠢的“[0m”。我不知道那里出了什么问题。)
SQL 显示“活动”布尔字段在选中时设置为 0。如何让它正确设置活动位?
作为后续行动,我将如何组织它以完全摆脱 Schedule“连接”?我想我需要从表单中提交一个带有时间表的 :_delete,但是当涉及一个复选框时,我将如何有条件地执行此操作?
感谢您的任何帮助,您可以提供。事实证明,Rails 对我来说是一个广阔的主题,我想“正确地”做它。我真的很接近这里,但必须有一种方法可以做到这一点——不仅仅是正确的——而且是优雅的。视图代码感觉太麻烦了,不能成为正确的 Rails。;-)